# Sundance Multiprocessor Technology Limited Application note

SUNDANCE

| Unit / Module Description: | SMT 339          |
|----------------------------|------------------|
| Document Issue Number:     | 1                |
| Issue Date:                | 25/09/07         |
| Original Author:           | Francois Godreau |

### CODESIGN, IMPLEMENTATION AND VALIDATION OF THE XILINX FPGA'S EMBEDDED DEVICES FOR SIGNAL PROCESSING SOLUTIONS

Sundance Multiprocessor Technology Ltd, Chiltern House, Waterside, Chesham, Bucks. HP5 1PS.

This document is the property of Sundance and may not be copied nor communicated to a third party without prior written permission. © Sundance Multiprocessor Technology Limited 2006



Certificate Number FM 55022

# Abstract

The design team develops rapid prototyping platforms for high-performance processing. These boards are independent modules populated by DSPs and FPGAs that can be interconnected via communication links. Sundance boards are typically based on TI DSP and Xilinx FPGAs which embed processors like the PowerPC or Microblaze.

Sundance provides basic software support for their modules. To complement this software, Sundance works in partnership with software companies. These companies provide highlevel design tools and methodologies that accelerate the design of applications based on a mixed DSP and FPGA systems. Although these companies provide solutions for the DSPs and FPGAs in the Sundance systems, no support for the PowerPC has yet been developed.

The Sundance SMT339 provides a TI DSP DM642 and a Xilinx FPGA-FX60 with two embedded PowerPCs which formed an ideal development platform for this application note. In addition to the SMT339, a SMT319 module was used to communicate with this design in the PowerPC. The SMT319 was connected to a host system on which debug information could be printed out. XILINX tools were used such as EDK to implement the embedded processor and XILINX ISE software to design the application.

Sundance FPGAs implements several types of communication resources that are used to communicate between modules. These are comport, SHB, SDB, RSL and SLB.

Keywords: FPGA; PowerPC, Microblaze, firmware, co-design, embedded processors

# **Table of contents**

| INTRODUCTION                         | <u>8</u> |
|--------------------------------------|----------|
| TABLE                                | 7        |
| 1 PROJECT DESCRIPTION                | <u></u>  |
| 1.1 THE MAIN OBJECTIVE               | 9        |
| 1.2 REQUIREMENT                      |          |
| 1.2.1 Processor choice               |          |
| 1.2.2 Communication resources        |          |
| 1.2.3 External memory                |          |
| 1.3 BACKGROUND                       |          |
| 1.3.1 Embedded processor             |          |
| 1.3.2 External ZBT memory            |          |
| 1.4 TEST BENCH CONFIGURATION         |          |
| 1.4.1 HARDWARE SET UP                |          |
| 1.4.2 Software set up                |          |
| 1.5 DESIGN IMPLEMENTATION            |          |
| 1.5.1 PowerPC block                  |          |
| 1.5.2 Comport link implementation    |          |
| 1.5.3 External ZBT memory controller |          |
| 1.5.4 Global implementation          |          |
| CONCLUSION                           | <u></u>  |
| REFERENCES                           |          |

# **Table of figures**

| Figure 1 design expected                                          | . 14 |
|-------------------------------------------------------------------|------|
| Figure 2 PowerPC hard processor                                   | . 15 |
| Figure 3 PowerPC405Fx block diagram                               | . 16 |
| Figure 4 CoreConnect bus architecture                             | . 17 |
| Figure 5 PowerPC405 CPU and CoreConnect based SOC example         |      |
| Figure 6 ZBT memory block diagram                                 |      |
| Figure 7 timing feature of the ZBT memory                         |      |
| Figure 9 SMT339 diagram block                                     |      |
| Figure 10 Simplified ISE / EDK Design Flow                        | . 24 |
| Figure 11 development cycle with Code Composer Studio             | . 25 |
| Figure 12 system assembly view                                    |      |
| Figure 13 blocks connexions                                       | . 28 |
| Figure 14 Block diagram PowerPC - GPIO                            | . 29 |
| Figure 15 application tab                                         |      |
| Figure 16 XPS output widows - software compiled                   | . 30 |
| Figure 17 test scheme                                             | . 31 |
| Figure 18 XMD PowerPC system connexion                            | . 32 |
| Figure 19 memory map without OPB bridge                           | . 33 |
| Figure 20 bus interface without OPB bridge                        |      |
| Figure 21 OPB bus protocol example                                | . 35 |
| Figure 22 IPIF module                                             | . 36 |
| Figure 23 map user port                                           | . 37 |
| Figure 24 system assembly view - ppc2firm core                    | . 38 |
| Figure 25 port ppc2firm                                           | . 38 |
| Figure 26 block diagram ppc2firm                                  | . 40 |
| Figure 27 ppc_wrapper entity                                      | .41  |
| Figure 28 interface between PB and IB                             | . 42 |
| Figure 29 external ports                                          | . 42 |
| Figure 30 conversion big Endian - little Endian                   | . 43 |
| Figure 31 top level entity                                        | . 43 |
| Figure 32 SMT library                                             |      |
| Figure 33 libraries used                                          |      |
| Figure 34 project hierarchy into ISE                              | . 45 |
| Figure 35 implementation processes into ISE                       | . 45 |
| Figure 36 update SmtTim.h file                                    |      |
| Figure 37 user application                                        | . 48 |
| Figure 38 test scheme for the com-port link                       | . 48 |
| Figure 39 test com-port link CCS - XMD debugger                   | . 50 |
| Figure 40 polling example                                         |      |
| Figure 41 IP catalog                                              |      |
| Figure 42 PLB top-level block diagram                             |      |
| Figure 43 synchronous memory clocked by FPGA output with feedback |      |
| Figure 44 system assembly view for ZBT design                     | . 57 |

### Sundance Multiprocessor Technology Limited

| 9 |
|---|
| 0 |
| 1 |
| 2 |
| 4 |
| 5 |
| 7 |
| 8 |
| 9 |
| 0 |
|   |

# TABLE

| Table 1 specification                                               | 13 |
|---------------------------------------------------------------------|----|
| Table 2 big Endian byte orderingTable 3 little Endian byte ordering |    |
| Table 4 Software version                                            | 25 |
| Table 5 design memory map                                           | 28 |
| Table 6 program size                                                | 32 |
| Table 7 device utilisation                                          |    |
| Table 8 memory map - ppc2firm                                       | 39 |
| Table 9 description of the signals Comport                          |    |
| Table 10 event block signals                                        |    |
| Table 12 connexion between EMC and ZBT memory                       | 56 |
| Table 13 address bus connexion                                      | 58 |
| Table 14 data bus connexion                                         | 59 |
| Table 15 memory map for the ZBT design                              | 60 |
| Table 16 memory test descrption                                     |    |
| Table 17 memory map global design                                   |    |

# INTRODUCTION

Sundance Multiprocessor Technology Limited is a British firm located in Chesham, to the North-west of London. As shows by its name, this company designs and produces boards, with processors on them, dedicated for high frequency acquisition and data processing application. These boards, built with DSPs and FPGAs, are designed to the Texas Instrument Module standard.

To communicate and synchronise the parallel processing on different targets, DSPs and FPGAs, the designers need methods and tools to fill these requirements. Sundance works in partnership with companies providing high level design tools to ease development of applications for the Sundance's systems. **3L** is a company that offers DIAMOND, a design tool which is optimised for the Sundance products.

Thanks to new technology, FPGAs now provide a hardware/software development target within a single programmable device. An FPGA embedded processor system offers many exceptional advantages compared to typical microprocessors. Because of this, Sundance's customers want to develop applications implementing embedded processors. As yet, Sundance has not provided solutions to implement an embedded processor such as PowerPC and Microblaze into its boards. It needs to develop reference designs providing solutions for its customers and application notes describing every design.

This design was split into three modular designs to make the implementation easier. The first design contained a PowerPC with Sundance communication resources. This design allowed an embedded processor to transfer data to another processor such as a DSP. The second design implemented a PowerPC with an external ZBT memory controller. This design provided 8MB external memory to the processor. The memory controller was connected onto both interconnect buses: On-Chip Peripheral Bus (OPB) and Processor Local Bus (PLB). The last design incorporated every element: external memory, two communication resources, GPIO LED, data On-Chip Memory-Bus, instruction On-Chip Memory-Bus, data-cache side, instruction-cache side and internal memory. Application notes are available to give some information about each phase of the project. Each design is based on the model 3L DIAMOND uses to describe a system (<u>3L Diamond</u>).

### **1** Project description

This chapter contains the aim of this design and its specification.

### 1.1 The main objective

Advances in FPGA technology allow manufacturers to insert more and more peripherals increasing the functionality of this chip into their FPGAs. In the latest FPGAs, you can find trimode Ethernet Media Acess Controller that operates at 10, 100 and 1000 Mb/s, 100 Mb/s to 3,2Gb/s serial transceivers, In Tegrated Endpoint Block for PCI Express Compliance delivering full PCI Express Endpoint functionality, high-speed clock management circuitry, dedicated DSP slices. Also, a wide array of FPGA hard-IP core blocks include embedded processors.

FPGA manufacturers like Xilinx spent a lot of money to promote their embedded systems. For example, Xilinx has been developing a tool to simply implementing Xilinx's IP cores and embedded processors. Thus, a lot of people are very interested by these embedded processors because they can develop a design with both hardware and software application within the same chip.

Sundance's customers are very interested to use the PowerPC. To answer customer demand, Sundance have to support these embedded processors which formed the basis of this application note.

### 1.2 Requirement

This project was split in several applications to make the implementation easier. But the whole of the following specifications should be enforced for every application. All specifications are contained in the **Table 1**.

#### 1.2.1 Processor choice

Sundance works in partnership with Xilinx foundation. Xilinx provides FPGA families that embed two kinds of processors: the Microblaze and the PowerPC. The Microblaze is a soft processor core optimized for Xilinx's FPGA, by contrast, the PowerPC, created by IBM, is a physical processor built into the FPGA silicon, which delivers several advantages. You can find more details about these processors in section that follow.

PowerPC is the architecture of choice in the embedded world. This kind of processor was used on game console such as Nintendo's GameCube and Wii, Sony's PlayStation 3 and Microsoft's Xbox 360 and in the personal computer market like Apple's Macintosh. The PowerPC architecture developed is very famous and the knowledge about this processor is quite important.

Contrary to the Microblaze, the PowerPC architecture is independent of the target and it is built from dedicated silicon. Its implementation into a design does not change the performances of the device.

Although the PowerPC provides features better than the Microblaze, only certain Xilinx FPGA families embed a PowerPC. Despite this, this application note implements a PowerPC because Sundance boards provide both co-design solutions: FPGA-DSP or FPGA-PowerPC. Thus, if the FPGA does not embed a PowerPC, the software application may be developed on the DSP. An application designed for a PowerPC can easily be moved to the Microblaze processor. In fact, these both processors provide the same communication resources. Similarly, IP blocs can be shared between the processor and the same programming language is used.

### 1.2.2 Communication resources

To allow the PowerPC to communicate with another processor such as a DSP, the host or FPGA, it has to implement the Sundance's communication resources. Typically, Sundance FPGAs implement four types of communication resources. These resources are implemented in firmware in the FPGA. The aim of this application note was not to implement all communication resources in the PowerPC. By using 3L DIAMOND the required communication resources are implemented automatically.

The following are types of communication resources:

- > comport
- Sundance digital bus
- global bus
- rocket IO serial link

The Comport link was chosen among other links to connect the PowerPC to another processor for many reasons.

Firstly, the Comport is the simplest of the Sundance communication resources. Its implementation on an FPGA would be easier and quicker than rocket IO links for example.

A basic application was developed allowing a PowerPC to transfer data to another processor. This would be easier to validate and improve it.

The Comport is usually used to download programs to processor TIMs. This method is used by DIAMOND to load boot code into processor TIM. Thus, it was important to implement this link to simplify the development of the DIAMOND PPC software.

The implementation of communication resources follow design guidelines set out by Sundance.

#### 1.2.3 External memory

On Sundance boards, some FPGAs are connected with an external memory. Fast memory is connected to FPGA allowing high speed data storage. Many kinds of memory may be connected with FPGA such as SDRAM, DDR, Flash. But a type of memory used on Sundance board provides interesting features.

Zero-bus turnaround (ZBT) SRAM with no bus latency memory is a synchronous-burst SRAM with a simplified interfaced that fully uses available bandwidth.

ZBT SRAM devices use the full bandwidth because they do not require turnaround cycles. A turnaround cycle is idle cycles between read and write or write and read operation.

An external ZBT memory controller was implemented to connect a ZBT SRAM with the PowerPC. According to PowerPC buses, data rate expected is 40MB/s.

This external memory is used to store data from the PowerPC. Thus, memory controller has to support several accesses like byte, half word (2 bytes) and word (4 bytes). And the memory map should be laid out to follow guidelines set out by DIAMOND. For example, internal memory must precede external memory.

| Peripherals         | External ZBT memory     | Comport link        | PowerPC           |  |
|---------------------|-------------------------|---------------------|-------------------|--|
| Features            | controller              |                     |                   |  |
| Туре                | ZBT - K7N321801M        | Com-port            | PPC 405           |  |
| Clock               | 100MHz                  | 50MHz               | 300MHz            |  |
| width               | 2x18bits (4Mbytes)      | 32bits              | -                 |  |
| Number device       | 2(separate)             | 2(comport 3 et 2) 2 |                   |  |
| Bus interface       | OPB/PLB s               | OPB                 | OPB/PLB           |  |
| Burst mode          | Supported               | -                   | -                 |  |
| Access mode         | 8bits – 16bits – 32bits | -                   | -                 |  |
|                     | read and write          |                     |                   |  |
| mode                | Pipeline                | -                   | -                 |  |
| Implementation      | IP block                | IP block-           | -                 |  |
|                     |                         | connector block     |                   |  |
| Internal memory     | Consecutive             | -                   | 64Kbytes          |  |
| External memory     | Consecutive             | -                   | 8Mbytes           |  |
| instruction-cache   | truction-cache -        |                     | 4Kbytes           |  |
| data asaka          |                         |                     | 416 h + to o      |  |
| data-cache          | -                       | -                   | 4Kbytes           |  |
| Data on-chip        | -                       | -                   | 16Kbytes          |  |
| memory(DOCM)        |                         |                     |                   |  |
| Instruction on-chip | -                       | -                   | 16Kbytes          |  |
| memory(IOCM)        |                         |                     |                   |  |
| Debug port          | -                       | -                   | JTAG              |  |
| Target              | virtex4                 | Virtex2P- virtex4   | Virtex2P- virtex4 |  |
| Sundance board      | SMT339,                 | SMT339,             | SMT339,           |  |
|                     | SMT398,                 | SMT398,             | SMT398,           |  |
|                     | SMT145FX                | SMT145FX,           | SMT145FX,         |  |
|                     |                         | SMT338VP            | SMT338VP          |  |

### Table 1 specification

The following scheme describes the design expected for this application note.



Figure 1 design expected

### 1.3 Background

This paragraph describes blocks implemented such as Sundance resources, external memory controller and PowerPC.

### 1.3.1 Embedded processor

As described before, there are two types of embedded processors. Hard and soft core.

A "soft" processor is built using the FPGAs general-purpose logic. The "soft" processor is described in a Hardware Description Language (HDL) or netlist. Unlike the hard processor, processor such as Microblaze must be synthesized and fit into the FPGA fabric.

Xilinx produces FPGA families that embed a physical processor core into the FPGA silicon. A processor built from dedicated silicon is referred to as a "hard" processor. Such is the case for the PowerPC. 405 inside the Xilinx Virtex-II Pro and Virtex-4 families.



Figure 2 PowerPC hard processor

In both soft and hard processor systems, the local memory, processor busses, internal peripherals, controllers, and memory controllers must be built from the FPGA's general-purpose logic.

The PowerPC 405 processor is a 32-bit implementation of the PowerPC embedded environment architecture that is derived from the PowerPC architecture. Specifically, the PowerPC 405 processor is an embedded PowerPC 405D5 (for Virtex-II Pro) or 405F6 (for Virtex-4) processor core. The term processor block is used throughout this document to refer to the combination of a PPC405, on-chip memory logic (OCM), an APU controller (Virtex-4 only), and the gasket logic and interface.

The processor core consists of a 5-stage pipeline, separate instruction and data cache units, virtual memory management unit (MMU), three timers, debug, and interface to other functions. **Figure 3** illustrates the logical organization of the PPC405Fx.



Figure 3 PowerPC405Fx block diagram

The PowerPC is designed along RISC principles, and allows for a superscalar implementation. The PPC405 supports both big-endian and little-endian byte ordering, but by default, the PowerPC Architecture is Big Endian. In Big Endian, the MSB of an instruction word is assumed to be at the lowest address.

| LSB  |      |      | MSB  |
|------|------|------|------|
| 0x03 | 0x02 | 0X01 | 0x00 |

| MSB  |      |      | LSB  |
|------|------|------|------|
| 0x03 | 0x02 | 0X01 | 0x00 |

Table 2 big Endian byte ordering

Table 3 little Endian byte ordering

In a Little Endian program the same instruction is arranged with the least significant byte (LSB) of the instruction word at the lowest numbered address.

CoreConnect<sup>™</sup> is an IBM-developed on-chip bus-communications link that enables chip cores from multiple sources to be interconnected to create entire new chips. The CoreConnect technology eases the integration and reuse of processor, system and peripheral cores within standard product platform designs to achieve overall greater system performance. The CoreConnect bus architecture includes the Processor Local Bus (PLB), the On-chip Peripheral Bus (OPB), a bus bridge, two arbiters, and a Device Control Register (DCR) bus.



Figure 4 CoreConnect bus architecture

The 64-bit Processor Local Bus (PLB) consists of a bus control unit, a watchdog timer, and separate address, write and read data path units with a three-cycle-only arbitration feature. It contains a DCR slave interface to provide access to its bus error status registers. It also contains a power-up reset circuit to insure that a PLB reset is generated if no external reset has been provided. The PLB consists of a central bus arbiter, the necessary bus control and gating logic, and all necessary bus OR/MUX structures. The PLB provides the entire PLB bus structure and allows for direct connection for up to 16 masters and 16 slaves.

The On-chip Peripheral Bus (OPB) implements a 32-bit address bus and a separate 32-bit data bus. Transaction widths can be full-word, half-word, or byte-size. The bus supports 8-, 16-, and 32-bit wide device interfaces (aligned on the left-most byte).

It's a synchronous bus, data transactions can take a single cycle (for matched clocks), and burst operations are supported. Designed to support slower peripherals, the OPB is implemented as a straightforward multimaster, arbitrated bus.

The DCR bus provides an alternative path to the system for setting the individual device control registers. With it, the host CPU can set up the device-control-register sets without loading down the main PLB. This bus has a single master, the CPU interface, which can Read or Write to the individual device control registers. The bus employs a ring implementation to connect the CPU interface to the devices, which are addressed via a 10-bit address bus. A separate 32-bit data bus transfers register data. This is a synchronous bus.

A bridge is a synthesizable core that permits transfers of code and data between two different buses as such the Advanced Microcontroller Bus Architecture (AMBA) advanced high-performance bus (AHB) and the CoreConnect PLB (see the **Figure 4**).

A typical system-on-a-chip (SOC) implementation based on the PowerPC 405 CPU and CoreConnect, uses a three level bus structure for system level communication, configuration and control functions. High bandwidth memory and system interfaces are tied to the PowerPC 405 Core via the Processor Local Bus (PLB). Less demanding peripherals share the On-chip Peripheral Bus (OPB) and communicate to the PLB through the OPB bridge.

This three level bus architecture provides common interfaces for the IP cores. This application note is according to this architecture. **Figure 5** illustrates a representative SOC configuration.



### Figure 5 PowerPC405 CPU and CoreConnect based SOC example

#### 1.3.2 External ZBT memory

This design was developed on the SMT339. On this board, 8 Mbytes of ZBT SRAM is provided as a FPGA memory resource. The memory is based on two separate Samsung K7N321801M-20 devices which are each 2M by 18-bit devices, allowing independent access of each device.

The K7N321801M is Synchronous Static SRAMs. The N*t*RAMTM, or No Turnaround Random Access Memory utilises all the bandwidth in any combination of operating cycles.



Figure 6 ZBT memory block diagram



The following figure explains the timing feature for this memory.

Figure 7 timing feature of the ZBT memory

Xilinx provides external memory controllers (Xilinx EMC PLB). These modules support data transfer between the Processor Local Bus or On-chip Peripheral Memory and external synchronous and asynchronous memory devices. These kinds of controller receive control signals from the PLB or OPB to read and write to external memory devices.

The PLB/OPB EMC supports PLB data bus widths of 8, 16, 32, 64bits and OPB data bus widths of 8,16,32 bits, and memory subsystem widths of 8, 16, 32 (64bits for PLB). However, this ZBT control does not support sleep mode, burst mode (memory mode), parity checking or parity generating. "This controller does not support burst mode" means that the user can read and write to the ZBT memory in burst mode but the burst sequence provides by the memory is not used; a signal is used to load a new external address or increment the initial burst counter. In this case, the ZBT memory loads a new external address every read or write access.

Some features of the OPB/PLB EMC can be parameterized such as number of separate memory banks, memory type (synchronous or asynchronous), data width of each memory bank, pipeline delay of each memory, read and write access times for each memory bank, enabling of data-width matching per memory bank, enabling burst support and enabling negative edge IO registers enabling of PLB burst and cache line transaction support. The descriptions of every OPB/PLB EMC parameters are described in the following section.

### 1.4 Test bench configuration

This section explains hardware and software required for this application.

### 1.4.1 Hardware set up

This application note was developed on the <u>SMT339</u>. This board is a dedicated high speed image processing module for use in a wide range of image analysis systems. The module can be plugged into a standard TIM single width slot and can be accessed by either a standard Comport, or Rocket Serial Link (RSL) Interface. The image processing engine is based upon the 'Texas Instruments' TMS320DM642 Video Digital Signal Processor. It is fully software compatible with C64x using Code Composer Studio.

The DM642 runs at a clock rate of 720MHz. It features two levels cache based architecture. There are 16K Bytes of level one program cache (Direct mapped), 16K Bytes of level one data cache (2-Way Set-Associative) and 256K Bytes of level two cache that is shared program and data space (Flexible RAM/Cache Allocation). TheDM642 can perform 4, 16 x 16 Multiplies or 8, 8 x 8 Multiplies per clock cycle.

A powerful Vitrex-4 FPGA (XC4VFX60-11) is used onboard as the FPGA processing unit for image data. 8 Mbytes of ZBT SRAM is provided as a FPGA memory resource. Processing functions such as Colour Space Conversion (CSC), Discrete Cosine Transforms (DCT), Fast Fourier Transforms (FFT) and convolution can be implemented, without using any of the DSP's resources. The Virtex 4FX60 has 2 Power PC hardware cores that can be incorporated into this design.

The basic block diagram of the SMT339 and its components is illustrated Figure 9.



Figure 8 SMT339 diagram block

There are two separate JTAG chains on the SMT339 module. One allows the DSP chain to be accessed while the other allows the Virtex 4 to be configured. The last one was used to debug the PowerPC with Xilinx Micro-Processor debug (XMD).

The <u>SMT 319</u> was connected to the SMT339 via comport link to print the result on the host.

The SMT319 is a Graphics and Imaging Module based on Texas Instruments (TI) highperformance, TMS320C6414 digital signal processor (DSP), that allows original equipment manufacturers (OEM) designers to easily capture, process and display images without any host computer involvement and as an embedded solution if necessary.

SMT319 is suitable for a wide range of image processing applications including, graphics, rendering of pictures and general-purpose display sub-systems in larger multiDSP processing systems. This solution is supported on major platforms like PCI, CPCI, PXI and VME.

The module also includes a Xilinx Virtex-II FPGA, which is configured to provide "C4x" style Com-Ports, or alternatively the Sundance Digital Link (SDL), a TIM compatible enhanced global bus, two Sundance High Speed Bus (SHB) and other control functions.

#### 1.4.2 Software set up

To simplify the design process, Xilinx offers several sets of tools. The Xilinx Embedded Development Kit (<u>EDK</u>) is a suite of tools and IP that allows to design a complete embedded processor system for implementation in a Xilinx Field Programmable Gate Array (FPGA) device.

EDK includes XPS and SDK software. Xilinx Platform Studio (XPS) is the development environment or GUI used for controlling the hardware and software development of the embedded processor system.

Software Development Kit (SDK) is an integrated development environment, complimentary to XPS, that is used for C/C++ embedded software application creation and verification. SDK is built on the Eclipse<sup>™</sup> open-source framework.

The Integrated Software Environment (ISE) is the foundation for Xilinx FPGA logic design. Because FPGA design can be an involved process, Xilinx has provided software development tools that allow the designer to circumvent some of this complexity. Various utilities such as constraints entry, timing analysis, logic placement and routing, and device programming have all been integrated into ISE.



Figure 9 Simplified ISE / EDK Design Flow

Like Xilinx, Texas Instrument provides several sets of tools. Code Composer Studio<sup>™</sup> integrated development environment includes host tools and target software that slashes development time and optimizes the performance for all real-time embedded DSP applications.

The CCStudio IDE includes DSP/BIOS support, real-time analysis capabilities, debugger and optimization tools, C/C++ Compiler, Assembler, Linker, integrated CodeWright editor, visual project manager, and a variety of simulators and emulation drivers.



Figure 10 development cycle with Code Composer Studio

Software required for this reference design is described in the following table:

| Software             |     | version |
|----------------------|-----|---------|
| ISE                  | ISE | 9.1 SP3 |
| <u>EDK</u>           | Ś   | 9.1 SP2 |
| Code Composer Studio |     | 3.3     |

 Table 4 Software version

### 1.5 Design implementation

The main objective explained and every specification defined, the next step is the implementation of this application.

### 1.5.1 PowerPC block

This paragraph demonstrates process of creating and testing a PowerPC system design using the Embedded Development Kit (EDK).

### 1.5.1.1 Overview

This design implemented the PowerPC block and General Purpose Input/Ouput (GPIO). This peripheral was used to flash LEDs on the board. The PowerPC was running at 100MHz like its communication links. By a basic example, this design allowed users to understand the PowerPC architecture and use Xilinx's software and hardware. In this example, the design flow was generated by EDK.

### 1.5.1.2 Constraints

According to the requirement, all system was running at 100 MHz to make easier the implementation. This constraint can be checked in the MHS file. The Microprocessor Hardware Specification (MHS) file describes the embedded processor: either the soft core MicroBlaze processor or the hard core PowerPC, peripherals and associated address spaces, buses and overall connectivity of the system.

The MHS file is a readable text file that is an input to the Platform Generator; the hardware system building tool. Conceptually, the MHS file is a textual schematic of the embedded system.

For the Sundance board, the bitgen file needs to be changed. It contains every setting for JTAG configuration. By default, the device is synchronised to the clock provided by JTAG.

This option specifies the start-up sequence for the device synchronisation. But Sundance's TIMs need clock system to download the bitstream before connecting to the JTAG. Thus, the default clock startup needs to be replaced by the clock provided in the FPGA device: "-g StartUpClk:CCLK".

If you don't change this parameter, you cannot download the bitstream into the FPGA with the Sundance package (SMT6001).

For design entry in VHDL, only a few constraint options can be embedded in the source code. In this case, designers have the option to use a UCF. User constraint files allow designers to manually control some of the following attributes in a FPGA design: pin and node assignments, slew rate control, fit options, input pin characteristics, initial register state, global clock use. In this design, the user constraint file contains only five pin assignments: Clk, Rst, LED(0 to 2).

This implementation includes both hardware and software. In fact, this design needs components such as PLB controller, BRAM...and a software application as well.

### **1.5.1.3** Hardware implementation

Figure 12 shows the system assembly view created with the Base System Builder.

| P O<br>L P                                | Filters<br>• • • Bus Interface O Ports |                | ≧v Filters (Applied | i)         |
|-------------------------------------------|----------------------------------------|----------------|---------------------|------------|
| BB                                        | Name                                   | Bus Connection | IP Type             | IP Version |
|                                           | і <u>в</u>                             |                | ppc405_virtex4      | 1.01.a     |
| <u>□</u> +•-⊳́                            | ⊕                                      |                | ppc405_virtex4      | 1.01.a     |
| ┝──┼┼┼┼──                                 | 🚋 - 🗢 plb                              |                | plb_v34             | 1.02.a     |
|                                           | 🗐 🗢 opb                                |                | opb_v20             | 1.10.c     |
| <del>       </del>                        | 🗊 🗢 jtagppc_0                          |                | jtagppc_ontlr       | 2.00.a     |
|                                           | 😥 🥯 reset_block                        |                | proc_sys_reset      | 1.00.a     |
| 🧅 🎍 🗕 — — — — — — — — — — — — — — — — — — | 🗊 🗢 plb2opb                            |                | plb2opb_bridge      | 1.01.a     |
| <u> </u>                                  | 🗊 🗢 LEDS                               |                | opb_gpio            | 3.01.Б     |
| ←                                         | 🗊 🗢 plb_bram_if_cntlr_1                |                | plb_bram_if_cntl    | r1.00.Б    |
| -                                         | 🗊 🗢 plb_bram_if_cntlr_1_bran           | r -            | bram_block          | 1.00.a     |
|                                           | 😥 🧼 dam_0                              |                | dcm_module          | 1.00.c     |

#### Figure 11 system assembly view

Both PowerPC cores were implemented: ppc405\_0 and pp405\_1. But only the ppc405\_0 was used. This basic example includes both CoreConnect bus architecture the Processor Local Bus (PLB) and the On-chip Peripheral Bus (OPB). The ports tab gives further information about the connectivity between the blocks.

| Name                          | Net                    | Dire       | ection   ( | Class | Sensitivity | Range | Frequency | Reset Polarity | IP Type          | IP Version |
|-------------------------------|------------------------|------------|------------|-------|-------------|-------|-----------|----------------|------------------|------------|
| 😑 🥯 External Ports            |                        |            |            |       |             |       |           |                |                  |            |
| fpga_0_LEDS_GPl0              | fpga_0_LEDS_GPI0_d_out | <b>v</b> 0 | ~          | ~     |             | [0:2] |           |                |                  |            |
| sys_clk_pin                   | dem_elk_s              | ✓          | 🗸 🗸 🗸      | CLK 🔽 |             |       | 100000000 |                |                  |            |
| sys_rst_pin                   | sys_rst_s              | <b>v</b> I | 🗸 F        | RST 🔽 |             |       |           | 0 💌            |                  |            |
| 🗐 🗢 ррс405_0                  |                        |            |            |       |             |       |           |                | ppc405_virtex4   |            |
| 🕀 🗢 ррс405_1                  |                        |            |            |       |             |       |           |                | ppc405_virtex4   | 1.01.a     |
| 🖨 🗢 plb                       |                        |            |            |       |             |       |           |                | plb_v34          | 1.02.a     |
| PLB_Clk                       | sys_clk_s              | ~          | C          | :LK   |             |       |           |                |                  |            |
| SYS_Rst                       | sys_bus_reset          | ~          |            |       |             |       |           |                |                  |            |
|                               | No Connection          | ✓ 0        |            |       |             |       |           |                |                  |            |
|                               | No Connection          | ✓ 0        | 11         | NTE   | EDGE_RI     |       |           |                |                  |            |
| 🖨 🥯 opb                       |                        |            |            |       |             |       |           |                | opb_v20          | 1.10.c     |
|                               | sys_clk_s              | ~          | C          | :LK   |             |       |           |                |                  |            |
|                               | sys_bus_reset          | ~          |            |       |             |       |           |                |                  |            |
| ı∎ 🗢 jtagppc_0                |                        |            |            |       |             |       |           |                | jtagppc_ontlr    | 2.00.a     |
| 🗄 🥯 reset_block               |                        |            |            |       |             |       |           |                | proc_sys_reset   |            |
| 🕀 🗢 plb2opb                   |                        |            |            |       |             |       |           |                | plb2opb_bridge   |            |
| $\blacksquare \bigcirc LEDS$  |                        |            |            |       |             |       |           |                | opb_gpio         | 3.01.Б     |
| 😑 🗢 plb_bram_if_cntlr_1       |                        |            |            |       |             |       |           |                | plb_bram_if_cntl |            |
| 📮 🗢 plb_bram_if_cntlr_1_bran. |                        |            |            |       |             |       |           |                |                  | 1.00.a     |
| 표 🥯 dcm_0                     |                        |            |            |       |             |       |           |                | dcm_module       | 1.00.c     |

Figure 12 blocks connexions

Blocks connexions allowed user to check the frequency, the reset polarity and every connexion between blocks. It is the graphic interface of the MHS file.

The following table shows the memory map for this design as created by Base System Builder.

| Device         | Address    |            | Size | Comment    |
|----------------|------------|------------|------|------------|
|                | Min Max    |            |      |            |
| PLB_BRAM_CNTLR | 0xFFFFC000 | 0xFFFFFFFF | 16K  | PLB Memory |
| OPB_GPIO       | 0x40000000 | 0x4000FFFF | 64K  | LED output |
| PLB2OPB        | 0x40000000 | 0x4000FFFF | 64K  | Bridge     |

#### Table 5 design memory map

It is important to check the address of every component. In fact, a peripheral can be controlled by the PowerPC, if it is part of PowerPC address range.

Figure 14 describes hardware component implemented by the wizard.

|                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>1</b> 476 |
|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| SPECS<br>EDK VERSION 8.8.8<br>ARCH voteor<br>PART xc-dwisemertS3-re<br>GENERATED The May 17 15-48.34 2007 | SYMBOLS<br>Symbols<br>Symbols<br>Stared Sur<br>Stared Sur<br>Sta |              |

Figure 13 Block diagram PowerPC - GPIO

After that the hardware had been completely specified in the MHS file, Platform Generator was able to run. Platform Generator elaborates the MHS file into a hardware system consisting of NGC files that represent the processor system. Then it can generate a netlist and create the bit file.

#### **1.5.1.4** Software implementation

The next step is defining the software design. There are two major parts to software design, configuring the Board Support Package (BSP) and writing the software applications. The configuration of the BSP includes the selection of device drivers and libraries.

Software application code development for this design is shown in Figure 15.



Figure 14 application tab

The Base System Builder (BSB) generates a sample application which tests a subset of the peripherals included in the design.

Both sources code TestApp\_Peripheral.c and xgpio\_tapp\_example.c were added to this project. They were generated by BSB. This application set the Led to high one following the other. These sources code were compiled using the GNU GCC Compiler.

The compiled software routines are available as an Executable Format (ELF) file. The ELF file is the binary ones and zeros that are run on the processor hardware.

| ×     | LibGen Done.<br>powerpc-eabi-gcc -02 TestApp_Peripheral/src/TestApp_Peripheral.c TestApp_Peripheral/src/xgpio_tapp_example.c -o TestApp_Peripheral/executable.elf \<br>-W1,-T -W1,TestApp_Peripheral/src/TestApp_Peripheral_LinkScr.ld -g -I./ppc405_0/include/ -ITestApp_Peripheral/src/ -L./ppc405_0/lib/ \<br>powerpc-eabi-size TestApp_Peripheral/executable.elf |             |             |             |     |                                               |  |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|-------------|-----|-----------------------------------------------|--|--|--|
| wopuj | text<br>3646<br>Done!                                                                                                                                                                                                                                                                                                                                                | data<br>332 | bss<br>2120 | dec<br>6098 | hex | filename<br>TestApp_Peripheral/executable.elf |  |  |  |

### Figure 15 XPS output widows - software compiled

#### **1.5.1.5** Test and validation

After that the hardware and software designs were completed, device can be configured. The Host was connected to the target board via the Parallel-JTAG cable IV.

The figure below shows the test scheme.



Figure 16 test scheme

The bitstream was downloaded by SMT6001 package. The main program of the SMT6001 package, the Flash Programming Utility, manages the Flash ROMs on Sundance TIMs. The Flash Programming Utility uses Texas Instruments' Code Composer<sup>™</sup> to allow the user to analyse the contents of a ROM and program new data. For added security, the Flash Programming Utility will also allow the user to erase the ROM completely.

Both files are generated by EDK: PPC.bit and download.bit. For software downloading: software can be initialized into the bitstream if it fits inside FPGA internal block RAM (BRAM) memory. Else the software debug tools can be used, such as the XPS Software Development Kit (SDK), to download a program to the board.

Download.bit file merges the FPGA bitstream and ELF files into a single bitstream file. When this bitstream is downloaded into the FPGA, application runs in standalone after a reset board. Opposed to PPC.bit file that only configures the device. This bitstream is used to debug the software directly via the JTAG PPC connections. GDB connects to the PowerPC core through the JTAGPPC and the Xilinx Microprocessor Debug (XMD) engine utility as shown in **Figure 18**. XMD is a program that facilitates a unified GDB interface and a TCL (Tool Command Language) interface for debugging programs and verifying microprocessor systems.



Figure 17 XMD PowerPC system connexion

This design was validated with these both methods. Before starting the next design, it was important to check features and the resources used by this application.

This design used 4 percents slices into the FPGA. Overview about the embedded processor shows both PowerPC implemented used no resource. That is according to the paragraph describing the embedded processor into FPGA. Indeed, this kind of processor is built from dedicated silicon. Thus, its implementation "doesn't use" FPGA resources.

The following **Table 6** explains the program size.

| Text(Kb) | Data | bss  | dec  | hex  |
|----------|------|------|------|------|
| 3646     | 332  | 2120 | 6098 | 17d2 |

Table 6 program size

| Post Synthesis Device Utilisation |      |           |         |  |
|-----------------------------------|------|-----------|---------|--|
| Resource Type                     | Used | Available | Percent |  |
| Slices                            | 1073 | 25280     | 3       |  |
| Slice Flip flops                  | 1024 | 50560     | 1       |  |

#### Table 7 device utilisation

More than 3 percents slices were used by the PLB controller and the PLB/OPB bridge. Thus, to optimise the resources used by a design, it would be more interesting to implement every peripheral onto the PLB bus.

Just to check this remark, a design without OPB bus interface was created. **Figure 19** shows the memory map and components attached to the PLB.

| Processor: PPC 405<br>Processor clock frequency: 100.000000 MHz<br>Bus clock frequency: 100.000000 MHz<br>Debug interface: FPGA JTAG<br>On Chip Memory : 16 KB<br>The address maps below have been automatically assigned. You can modify them using the<br>editing features of XPS. |                                       |                              |                     |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------------------|---------------------|--|--|--|
|                                                                                                                                                                                                                                                                                      |                                       |                              |                     |  |  |  |
| -<br>PLB Bus : PLB_V                                                                                                                                                                                                                                                                 | 34 Inst. name: plb /                  | Attached Compor              | ients:              |  |  |  |
| PLB Bus : PLB_V<br>Core Name                                                                                                                                                                                                                                                         | 34 Inst. name: plb /<br>Instance Name | Attached Compor<br>Base Addr | ients:<br>High Addr |  |  |  |
| _                                                                                                                                                                                                                                                                                    |                                       |                              |                     |  |  |  |

Figure 18 memory map without OPB bridge

The following Figure 20 explains bus interfaces. None OPB bus was implemented.

| P        | Filters       Filters       Image: Second state       Image: Second sta |                       |                  |            |  |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------|------------|--|--|
| B        | Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <b>Bus Connection</b> | IP Type          | IP Version |  |  |
| 😐 🖓 🔶    | 🗐 🗢 ррс405_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                       | ppc405_virtex4   | 1.01.a     |  |  |
| ÷-÷      | ₽                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       | ppc405_virtex4   | 1.01.a     |  |  |
|          | 庄 🗢 plb                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       | plb_v34          | 1.02.a     |  |  |
| <u> </u> | 🕀 🗢 jtagppc_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                       | jtagppc_cntlr    | 2.00.a     |  |  |
|          | 🕀 🧼 reset_block                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | proc_sys_reset   | 1.00.a     |  |  |
|          | <u> <u> </u> <u> </u> <u> </u> <u> </u> <u> </u> <i> </i></u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                       | plb_gpio         | 1.00.Б     |  |  |
| ←        | 🕞 🧼 plb_bram_if_cntlr_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       | plb_bram_if_cntl | г1.00.Б    |  |  |
| <b>-</b> | 🕀 🧼 🗩 plb_bram_if_cntlr_1_bran                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | c .                   | bram_block       | 1.00.a     |  |  |
|          | 🕀 🧼 dcm_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                       | dcm_module       | 1.00.c     |  |  |

Figure 19 bus interface without OPB bridge

Only one percent slices was used by this design. This feature is quite important when the area is critical.

### 1.5.2 Comport link implementation

The first design allowed you to create and test a PowerPC system design using the Embedded Development Kit (EDK). In this section, the Comport link was implemented to improve the previous design. The first step defined the requirements.

#### 1.5.2.1 Overview

This design implemented an external peripheral: Comport. The Comport was instantiated like an IP core. A Xilinx's module was used to provide an interface between the OPB bus and the Comport IP core. This design was exported to ISE for the Comport block integration. Indeed, ISE describes every step of the design flow and control the hardware implementation in the FPGA. The Comport link should transfer data to 20MB/s. Every bus and PowerPC had to run at 100MHz according to the specifications.

#### 1.5.2.2 Constraints

The Comport link must be implemented according to Sundance concept of view. All of the Sundance TIMs provide mechanisms to transfer data between modules. The mechanisms are implemented on the TIMs using FPGAs.

The FPGA (Field Programmable Gate Array) is a device that can be configured by software to implement hardware functions. Sundance TIMs use FPGAs to create peripheral devices such as Comports.

Before a TIM can access the mechanisms that will allow it to communicate with other modules, the DSP must load the FPGA with appropriate firmware. This firmware is held in the FPGA data segment of the flash, and will be installed in the FPGA each time the bootloader executes.

Sundance uses modularity in its designs to improve reusability and maintainability. This approach creates a number of blocks which are used to create the firmware. The role of the firmware is to allow these peripherals to exchange data.

The FPGA is connected to the peripherals via physical wires and these peripherals may be zero or more processors or connectors or other components on the module.

The firmware includes **processor blocks**, **interface blocks**, and **connector blocks**. All blocks are interconnected with pre-defined signals. The connector and processor blocks are connected to the physical pins of the FPGA. This is a standard case of figure. Some modules do not have a processor connected to the FPGA. Usually the firmware for these modules makes use of the standard connector blocks, but the processor and interface blocks may be replaced by a custom controller block.

The next section explains how the Comport link was implemented.

#### 1.5.2.3 Hardware implementation

One of the key advantages of building an embedded system in an FGPA is the ability to include customer IP and interface that IP to the processor. The processor system by EDK is connected by OPB and/or PLB bus, so this custom peripheral: Comport, must contain a set of bus ports that is compliant to OPB or PLB protocol.

To connect the custom peripheral, Comport, to the PowerPC, the IP core must be attached the system OPB or PLB bus as shown the **Figure 21**.



Figure 20 OPB bus protocol example

Meaning the top-level module of the custom peripheral must contain a set of bus ports that is compliant to OPB or PLB protocol. Another constraint adds to this one.

To use the custom peripheral in XPS, the peripheral must be stored in a place (directory structure) that is accessible by various EDK tools; and it must have the correct Platform Specification Format interface files: MPD and PAO files. But Xilinx provides Intellectual-Property Interface (IPIF) library to implement common functionality among various processor peripherals.

Both OPB/PLB IPIF are designed to provide a bidirectional interface between a user IP core and the IBM OPB or PLB Bus.

The back end interface standard, the Xilinx IPIC, is common in most aspects between IPIF modules in various versions for the OPB and the PLB for the features supported. This allows IP blocks using the IPIC to be adapted for either the OPB or the PLB. **Figure 22** shows a block diagram of the OPB IPIF.



Figure 21 IPIF module

According to the specification, the custom peripheral was connected to the OPB bus. The IPIF was generated by "Create and Import Peripheral Wizard" functionality. It was called "ppc2fir". It means PowerPC to firmware. The wizard automatically created corresponding OPB peripheral templates to add the custom peripheral. Two HDL template files were generated: peripheral top-level and user-logic HDL templates.

The top-level file, ppc2fir.vhd, is the template file for the peripheral's top design entity. It configures and instantiates the corresponding IPIF unit in the way you indicated in the wizard GUI and connect it to the stub user logic where the user logic should get implemented.

The recommended design using wizard is added the user port mapping in the top-level file and incorporated the custom IP functionality in the file user\_logic. In this case, the software can access to the peripheral thanks to the software addressable registers. It means the user logic component of the peripheral has registers that are addressable through software. But the Comport IP was not implemented according to this recommendation.

The Comport implementation needed high constraint onto these control signals. It was easier to define these constraints in ISE. This software describes every step of the design flow allowing designers to check every step to see if the constraints were met. So the Comport IP functionality was not implemented in the user\_logic file.

Indeed, the user port mapping was just added in the top-level file as shown **Figure 23** and the user\_logic component instantiation was deleted. The ppc2firm core was connected to the Comport link in Xilinx ISE.

```
port
(
 -- ADD USER PORTS BELOW THIS LINE -----
 --USER ports added here
 Bus2IP Clk
                             : out std logic;
 Bus2IP Reset
                             : out std logic;
 Bus2IP Addr
                             : out std logic vector(O to C AWIDTH-1);
 Bus2IP RNW
                             : out std logic;
 IP2Bus Ack
                             : in std logic;
 IP2Bus Retry
                             : in std logic;
 IP2Bus Error
                             : in std logic;
 IP2Bus ToutSup
                             : in std logic;
 Bus2IP ArData
                             : out std logic vector (O to C MAX AR DWIDTH-1);
 Bus2IP ArBE
                             : out std logic vector(O to C MAX AR DWIDTH/8-1);
 Bus2IP ArCS
                             : out std logic vector(O to C NUM ADDR RNG-1);
                              : in std logic vector (O to C MAX AR DWIDTH-1);
 IP2Bus ArData
 -- ADD USER PORTS ABOVE THIS LINE ------
```

#### Figure 22 map user port

Figure 24 shows the system assembly view in EDK implementing the "ppc2firm" core.

| Project Informa                | tion Area    |              | × |       |      | •        | Filters         |             |                       |                  |            |
|--------------------------------|--------------|--------------|---|-------|------|----------|-----------------|-------------|-----------------------|------------------|------------|
| IP Catalog                     | Project      | Applications |   | 0     | Р    |          | 💿 Bus Interface | O Ports     | O Addresses           | Prion F €        | ilters     |
| •                              |              |              |   | P     | Ĺ,   | Nar      | ne              |             | <b>Bus Connection</b> | IP Type          | IP Version |
| Θ                              |              |              |   | B     | B    | ÷        | 🗢ррс405_0       |             |                       | ppc405_virtex4   | 1.01.a     |
| Name 🔺                         |              | Version      |   |       |      | Ð        | ppc405_1        |             |                       | ppc405_virtex4   | 1.01.a     |
| 😟 Analog                       |              |              |   | 1     | 11   | - T .    | 🧇 plb           |             |                       | plb_v34          | 1.02.a     |
| <ul> <li>Arithmetic</li> </ul> |              |              |   |       |      | ÷.       | 🗢 opb           |             |                       | opb_v20          | 1.10.c     |
| 🖶 Bus                          |              |              |   |       |      |          | ⇒plb2opb        |             |                       | plb2opb_bridge   | 1.01.a     |
| 🛓 Bus Bridge                   |              |              |   | I T I |      |          | ⇒jtagppc_0      |             |                       | jtagppc_cntlr    | 2.00.a     |
| 🗄 Clock Cont                   | rol          |              |   |       | ``   | <u> </u> | LEDS            |             |                       | opb_gpio         | 3.01.Б     |
| 🛓 Communica                    | ation High-S | ipeed        |   | L T   |      |          | plb_bram_if_cn  | tlr_1       |                       | plb_bram_if_cntl |            |
| 🗄 Communica                    | ation Low-S  | peed         |   |       | - T. | <b>-</b> | ppc2fir_0       |             |                       | ppc2fir          | 1.00.a     |
| 🗄 Debug                        |              |              |   | 📥     |      | _        | SOPB            |             | opb                   |                  |            |
| 🖻 DMA                          |              |              |   | T     |      |          | reset_block     |             |                       | proc_sys_reset   |            |
| 🗉 FPGA Rec                     | onfiguration | 1            |   |       |      | _        | plb_bram_if_cn  | itlr_1_bram | l                     | bram_block       | 1.00.a     |
| 🕒 General Pu                   | rpose IO     |              |   | l'    |      | <b>.</b> | ⊲dcm_0          |             |                       | dcm_module       | 1.00.a     |
| 🕒 Interrupt Co                 | ontrol       |              |   |       |      |          |                 |             |                       |                  |            |
| 🕒 Memory Blo                   | ock          |              |   |       |      |          |                 |             |                       |                  |            |
| 🛓 Memory Co                    | Introller    |              |   |       |      |          |                 |             |                       |                  |            |
| 🗉 PCI                          |              |              |   |       |      |          |                 |             |                       |                  |            |
| 连 Peripheral (                 | Controller   |              |   |       |      |          |                 |             |                       |                  |            |
| 📮 Peripheral F                 | Repositorie: | s            |   |       |      |          |                 |             |                       |                  |            |
| 👘 🔵 ppc                        | c2fir        | 1.00.a       |   |       |      |          |                 |             |                       |                  |            |
| Processor                      |              |              |   |       |      |          |                 |             |                       |                  |            |
| 🗉 Reset Cont                   | trol         |              |   |       |      |          |                 |             |                       |                  |            |
| 🗉 Timer                        |              |              |   |       |      |          |                 |             |                       |                  |            |
| 🛓 Utility                      |              |              |   |       |      |          |                 |             |                       |                  |            |

Figure 23 system assembly view - ppc2firm core

The following figure shows the ports for the ppc2firm bloc implemented. These were defined by the wizard. They are always present. These signals correspond to the interface provided from the IPIC bloc.

| Name                    | Net                     | Direction | Class | Sensitivity | Range                       |
|-------------------------|-------------------------|-----------|-------|-------------|-----------------------------|
| ⊕ ◆External Ports       |                         |           |       | -           |                             |
| 🕀 🗢 ррс405_0            |                         |           |       |             |                             |
|                         |                         |           |       |             |                             |
| 🛓 - 🧼 plb               |                         |           |       |             |                             |
| 🖶 - 🧼 opb               |                         |           |       |             |                             |
| 🗊 🗢 plb2opb             |                         |           |       |             |                             |
| 🗊 🗢 jtagppc_0           |                         |           |       |             |                             |
| 🗊 🗢 LEDS                |                         |           |       |             |                             |
| 👜 🗢 plb_bram_if_cntlr_1 |                         |           |       |             |                             |
| 📮 🥌 ppc2fir_0           |                         |           |       |             |                             |
| Bus2IP_Clk              | ppc2fir_0_Bus2IP_Clk    | 0         |       |             |                             |
| Bus2IP_Reset            | ppc2fir_0_Bus2IP_Reset  | 0         |       |             |                             |
| Bus2IP_Addr             | ppc2fir_0_Bus2IP_Addr   | 0         |       |             | [0:(C_AWIDTH-1)]            |
| -Bus2IP_RNW             | ppc2fir_0_Bus2IP_RNW    | 0         |       |             |                             |
| IP2Bus_Ack              | ppc2fir_0_IP2Bus_Ack    | I         |       |             |                             |
| IP2Bus_Retry            | ppc2fir_0_IP2Bus_Retry  | I         |       |             |                             |
| IP2Bus_Error            | ppc2fir_0_IP2Bus_Error  | I         |       |             |                             |
| IP2Bus_ToutSup          | ppc2fir_0_IP2Bus_ToutS  | upl       |       |             |                             |
| Bus2IP_ArData           | ppc2fir_0_Bus2IP_ArData | a O       |       |             | [0:(C_MAX_AR_DWIDTH-1)]     |
| Bus2IP_ArBE             | ppc2fir_0_Bus2IP_ArBE   | 0         |       |             | [0:((C_MAX_AR_DWIDTH/8)-1)] |
| Bus2IP_ArCS             | ppc2fir_0_Bus2IP_ArCS   | 0         |       |             | [0:(C_NUM_ADDR_RNG-1)]      |
| IP2Bus_ArData           | ppc2fir_0_IP2Bus_ArData | a I       |       |             | [0:(C_MAX_AR_DWIDTH-1)]     |
| 庄 🧼 reset_block         |                         |           |       |             |                             |

Figure 24 port ppc2firm

An address can be defined for the newly added ppc2firm peripheral by entering the Base Address. The following table describes the memory map of this application.

| Device         | Add        | ress       | Size | Comment              |
|----------------|------------|------------|------|----------------------|
|                | Min        | Max        |      |                      |
| PLB_BRAM_CNTLR | 0xFFFFC000 | 0xFFFFFFF  | 16K  | PLB Memory           |
| OPB_GPIO       | 0x40000000 | 0x4000FFFF | 64K  | LED output           |
| PLB2OPB        | 0x40000000 | 0x4000FFFF | 64K  | Bridge               |
| ppc2firm       | 0x70000000 | 0x7007FFFF | 512K | Custom<br>peripheral |

Table 8 memory map - ppc2firm

The following figure describes the hardware implemented. Compare to the previous design, a new block appear onto the OPB. This block is the custom peripheral: ppc2firm.



Figure 25 block diagram ppc2firm

As soon as all hardware is defined in the MHS file, Platform Generator can run. Platform Generator elaborates the NGC files that represent the processor system. Then, Xilinx ISE tools are called to implement the design for the target board. It generates a netlist and creates the bit file. So, the EDK project needs to be exported into ISE.

You have to create a new Project Navigator project in ISE and add the ppc.xmp in the New Project Wizard - Add Existing Sources dialog window. In this project, two files have to be created. A file that instantiated the PowerPC with its ports and a top level file that implemented the com-port architecture: interface block and connector block.

ISE offers functionality to generate the PowerPC instantiation template. This option, called "View HDL Instantiation Template" generates a vhi file.

The file ppc\_wrapper instantiated the PowerPC and provided the interface between the IPIC and the Comport IP core. This file delivered the following entity:

```
use Smt.CB_pkg.all;
entity ppc_wrapper is
  generic(
        C_AWIDTH : integer := 32;
        C_MAX_AR_DWIDTH : integer := 32;
        C_NUM_ADDR_RNG : integer := 1
      );
    port(
        clk : in std_logic;
        nrst : in std_logic;
        Leds : out std_logic_vector(0 to 2);
        i_ib : in t_PB_IB_Y;
        o_ib : out t_PB_IB_X
        );
end ppc_wrapper;
```

#### Figure 26 ppc\_wrapper entity

Both signals i\_ib and o\_ib were used to connect the processor block to the interface. Signals provided by processor block to interface block are grouped in the type t\_PB\_IB\_X. The signals provided by interface block to processor block are gathered in the type t\_PB\_IB\_Y. Table 9 gives the description of the signals of the Comport interface block.

| 5          | ignals coming | g from processor block (type t_PB_IB_X)                                                   |
|------------|---------------|-------------------------------------------------------------------------------------------|
| I_pb.clk   | In            | Processor block clock. All signals constituting bus i_pb are<br>synchronous to this clock |
| I_pb.rst   | In            | General reset for interface block                                                         |
| I_pb.addr  | In            | Address bus                                                                               |
| I_pb.data  | In            | Data bus                                                                                  |
| I_pb.read  | In            | Read request                                                                              |
| I_pb.write | In            | Write request                                                                             |
|            | Signals goin  | g to processor block (type t_PB_IB_Y)                                                     |
| 0_pb.clk   | Out           | Tri-stated                                                                                |
| 0_pb.rst   | Out           | Tri-stated                                                                                |
| O_pb.addr  | Out           | Tri-stated                                                                                |
| O_pb.data  | Out           | Data bus                                                                                  |
| O_pb.read  | Out           | Tri-stated                                                                                |
| O_pb.write | Out           | Tri-stated                                                                                |

#### Table 9 description of the signals Comport

Figure 28 shows the connection between processor block and interface block



Figure 27 interface between PB and IB

The ppc\_wrapper file instantiated the PPC block with these ports. Indeed, every external port defined in EDK project had been declared in the PowerPC component.



Figure 28 external ports

The VHDL program following the PowerPC instantiation drives signals between Comport and PowerPC external ports (bus signals).

Both data bus and address bus needed processing because the PowerPC provided signals in big Endian and the comport protocol worked in little Endian. This processing is descried by

the Figure 30.

```
g_data_bus_rev: for i in 0 to 31 generate
    o_ib.data(31-i) <= Bus2IP_ArData(i);
    ar_data_out(0)(i) <= i_ib.data(31-i);
end generate;

g_add_bus_rev:for i in 12 to 19 generate
    o_ib.Addr(31-i) <= Bus2IP_Addr(i);
end generate;
</pre>
```

#### Figure 29 conversion big Endian - little Endian

The second file, top.vhd, instantiated the connector block, the interface block and provided signals to the PowerPC component.

This file was the top level of this design. So, it provided signals to drive the physical wires. In its entity, only four signals were defined: the clock system, the reset, Leds and the comport link.

#### Figure 30 top level entity

The "t\_Comport\_Pins" type describes the comport bus. This signal formed the interface to the pins of the FPGA. Other signals were used such as "t\_TriggerVector" and "t\_TriggerControl". The signal "t\_TriggerControl" was used to signals go from event block. Contrary to "t\_TriggerVector" that was used to signals go to event block. **Table 10** gives the description of these signals.

| Sig                                                 | nals coming | rom event block (type t_TriggerControl)                                                                                                                                               |  |  |
|-----------------------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| i_trig_ctl(10) In                                   |             | Triggers generation control.<br>When i_trig_ctl(i) is high, trigger generation is enabled. When<br>i_trig_ctl(i) is low, trigger generation is disabled and o_trigger(i)<br>stays low |  |  |
| Signals going to event block (type t_TriggerVector) |             |                                                                                                                                                                                       |  |  |
| O_trigger(0).trigger                                | Out         | Input condition asserted event (pulse)                                                                                                                                                |  |  |
| O_trigger(0).flag                                   | Out         | Input FIFO not empty                                                                                                                                                                  |  |  |
| O_trigger(0).trigger_latch                          | Out         | Latched version of O_trigger(0).trigger                                                                                                                                               |  |  |
| O_trigger(1).trigger                                | Out         | Output condition asserted event (pulse)                                                                                                                                               |  |  |
| O_trigger(1).flag                                   | Out         | Output FIFO not empty                                                                                                                                                                 |  |  |
| O_trigger(1).trigger_latch                          | Out         | Latched version of O_trigger(1).trigger                                                                                                                                               |  |  |

Table 10 event block signals

The program instantiated both components "IB\_Comport\_3" and "cb\_comport\_rcx". These blocks provided signals according to comport specifications.

To use these specials types, a new library must be created. It called SMT. This library was defined in the libraries tab into ISE. **Figure 32** shows the library created.



Figure 31 SMT library

Into VHDL files, this new library may be used thanks to the following sentence: library Smt. Here was every library and package defined in this design.

```
-- (c) sundance multiprocessor technology
Library IEEE;
use IEEE.std_logic_1164.all;
use ieee.numeric_std.all;
library Smt;
use Smt.Smt_pkg.all;
use Smt.Smt_misc_pkg.all;
use Smt.IB_pkg.all;
use Smt.CB_pkg.all;
use Smt.CB_comport_rcx_pkg.all;
use Smt.CB_Comport_Pads_pkg.all;
use Smt.IB_Comport_3_pkg.all;
use work.ppc_pkg.all;
```

Figure 32 libraries used

By adding ppc\_wrapper.vhd and top.vhd to the Project Navigator project the hierarchy was updated as shown in **Figure 34**.



Figure 33 project hierarchy into ISE

Constraints have to be implemented onto the comport link. They are defined in the ucf file. The hierarchy has changed now that the EDK system is instantiated inside the ppc\_wrapper module so the PPC reset pins are no longer available in the top level module. You need to add a \*/ in front of signals C405RSTCORERESETREQ, C405RSTCHIPRESETREQ, C405RSTSYSRESETREQ. That allows the tools to "wildcard" the hierarchy preceding the PPC reset pins.

In order to implement the Comport according to the protocol, several constraints must be defined such as timing constraint and pin assignments. These constraints are always required when the Comport link is implemented into a design. This ucf file also included the Led, clk and reset pin assignments.

After this step, the design was ready to be implemented. When the bitstream was generated by ISE, it was called XPS to generate the VHDL file that defined the processor system, the NGC files and the finally bitstream. Every step of the design flow can be checked thanks to the following windows



Figure 34 implementation processes into ISE

This step allowed users to check the resources required by the IP core. The ppc2firm block required 78 slices. This block included only the IPIF because the com-port was not implemented into this block.

The following synthesis options have been chose such as optimisation strategy, perform timing-driving packaging and placement that improved place and route into the FPGA. Yet, the full design used 2 percents of slices. After bitstream generation, the software design must be defined.

#### 1.5.2.4 Software implementation

A software program must be developed to use the Comport link. This link is controlled by four registers:

- Event Control Register (CP\_ECR)
- Global Status Register (CP\_GSR)
- Control and Status Register (CP\_CSR)
- Data Register (CP\_DAT)

Using these registers, it is possible to transfer data using a Comport with the following techniques:

- Polling
- Interrupts
- ➢ EDMA

But the block IPIF instantiated did not implement interrupt source and develop an example with the EDMA would have been too difficult. So, this application note polls the registers of the comport.

The program implemented was easy. Only one com-port was designed, the PowerPC received data from the com-port and displayed it.

This program used the function "cpread" defined in the "SmtTim.h" file. Sundance provides this package to its customers to make the Comport interface easier.

The function "cpread" polled the status and control register of the Comport (bit 26: IFE). And, it read back one word to the data register of the Comport 3 when there is one word available to read in the data register.

EDK provided libraries to use the custom peripheral implemented. Here was the function provided by EDK to read a value from Comport:

XIo\_In32((BaseAddress) + (RegOffset))

BaseAddress was the base address of the PPC2FIR device and RegOffset was the register offset from the base to write to. This function took as parameter the address register and not the comport number such as the Sundance's macros.

To simplify this implementation for the Sundance's customers, a function "cpread" and "cpwrite" was defined. They are defined in the header file "SmtTim.h". If these functions are used with a PowerPC, only the variable SMTPPC should be defined in the main program.

Figure 36 explains the improvements in the "SmtTim.h" file.

```
#if defined SMTPPC
#if defined _BASE
#define _FPGA(X) (volatile unsigned int *)((__BASE)+(X))
#define CPN_DAT(N) _FPGA(CPN_DAT_OFFSET(N)) /* comport data register */
#define CPN_CSR(N) _FPGA(CPN_CSR_OFFSET(N)) /* comport control and status register*/
.
.
#else // SMTPPC
#define CPN_DAT(N) XIo_In32(_FPGA(CPN_DAT_OFFSET(N)))
#define CPN_CSR(N) XIo_In32(_FPGA(CPN_CSR_OFFSET(N))) /* comport control and status register */
.
.
#endif // _BASE
#endif // _SMTPPC
```

#### Figure 35 update SmtTim.h file

In which time the CPN\_DAT or CPN\_CSR macros are called by the main program, if SMTPPC was defined, the function XIo\_In32() provided by EDK is executed to read a data from com-port.

Figure 37 shows the user application with EDK.

| IP Catalog Project Applications                                                                                                                                                                                                        |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Software Projects                                                                                                                                                                                                                      |  |
| - California Application Project                                                                                                                                                                                                       |  |
| - Martin Default: ppc405_0_bootloop                                                                                                                                                                                                    |  |
| - Martin Default: ppc405_1_bootloop                                                                                                                                                                                                    |  |
| 😑 🎇 Project: TestApp_Peripheral                                                                                                                                                                                                        |  |
| Processor: ppc405_0 Executable: D:\CUST\stage3annee\design\SMT339\PPC\Synthesis\ppc\TestApp_Peripheral\executable.elf                                                                                                                  |  |
| E Compiler Options<br>Sources                                                                                                                                                                                                          |  |
| D:\\CUST\stage3annee\design\SMT339\PPC\Synthesis\ppc\TestApp_Peripheral\src\TestApp_Peripheral.src\xgpio_tapp_example.     D:\\CUST\stage3annee\design\SMT339\PPC\Synthesis\ppc\TestApp_Peripheral\src\xgpio_tapp_example.     Headers |  |
| <sup>t</sup> TestApp_Peripheral\src\gpio_header.h                                                                                                                                                                                      |  |

#### Figure 36 user application

#### 1.5.2.5 Test and validation

For this application, another board was required to test the comport link. The same method and the same tools were used in this application and the first design.

Testes were split in two parts. The first part tests the comport link between the SMT339 and the 319 with no processing. It means the program described above was not used in this step. Only the comport registers were tested in this first parts. The second part ran the polling program. The following figure shows the scheme used in the first step.



Figure 37 test scheme for the com-port link

As shown this figure the SMT319 was used to test this design. Only the DSP on this board was used. It allowed user to transmit data from SMT 319 to the SMT339 via Comport. For this test, you need to connect physically the Comport 1 of the module 1 (SMT319) to the Comport 3 of the module 2 (SMT339).

The SMT319 module was used to transmit and check data receive by the module 2. For that, Code Composer Studio (CCS) was used to transfer a data to the PowerPC via the Comport link. The data received by the PowerPC could be checked thanks to the XMD debugger.

The base address of the Comport 1 is reauired to check the Comport registers in CCS. It is available in the user guide. For the SMT319, the base address of the Comport 1 is 0x90008000. And for the SMT339, the base address of the comport 3 is 0x70018000.

**Figure 39** shows an example sending a data from the module 1 with CCS to the module 2. A data "1" was sent onto the comport 1 (address 0x90008000). The XMD memory windows displayed the data received by the PowerPC via the Comport 3 link.



Figure 38 test com-port link CCS - XMD debugger

With this method, you are able to check every comport register. You can improve this test with the polling application.

The second part of this test uses polling application described in the previous section.

The value read from the comport 3, by the PowerPC, could be checked with the variable "read" in the local variable widows. **Figure 40** shows an application with the polling program.



Figure 39 polling example

With this examples, the PowerPC can communicate with another processor according to the Sundance resources. The link implemented can sustain a data rate of about 20MB/s according to Sundance's requirements. PowerPC and its peripherals run at 100MHZ.

#### 1.5.3 External ZBT memory controller

#### 1.5.3.1 Overview

For the third design, an external ZBT memory controller was implemented to the PowerPC with the first design by beginning. This controller was chosen in the Xilinx's IP cores library. The design flow was generated by EDK. Both controllers: OPB EMC and PLB EMC were implemented in two separated design in order to provide several hardware configurations for Sundance's customers. A design with the two ZBT banks is also available.

In this design, ZBT memory was running at 100MHz like every peripheral connected to the PowerPC. The data rate expected was 40MB/s between the PowerPC and the ZBT memory.

#### 1.5.3.2 Constraints

Every design was implemented onto the SMT339. This board provides two ZBT SRAM memory banks directly connected to FPGA pins. The PLB EMC memory controller provided by Xilinx was implemented. It is available is the IP Catalog tab. The IP Catalog tab shows all of the IP that are available to use in the EDK project.

| Project Inform           | ation Area  |              | ×           |
|--------------------------|-------------|--------------|-------------|
| IP Catalog               | Project     | Applications |             |
| ۲                        |             |              |             |
| •                        |             |              |             |
| Name 🔺                   |             | Version      | Description |
| 🕀 Analog                 |             |              |             |
| 🕀 Arithmetic             |             |              |             |
| 🕀 Bus                    |             |              |             |
| 🕀 Bus Bridge             | 9           |              |             |
| 🕀 Clock Con              |             |              |             |
| 🕀 Communic               | -           |              |             |
| 🕀 Communic               | ation Low-9 | opeed        |             |
| 🕀 Debug                  |             |              |             |
| 🕀 DMA                    |             |              |             |
| 🕀 FPGA Red               | -           | n            |             |
| 🕀 General P              | •           |              |             |
| Interrupt C              |             |              |             |
| 🕀 Memory B               |             |              |             |
| Memory C                 | bntroller   |              |             |
| D PCI                    |             |              |             |
| Peripheral               |             |              |             |
| Peripheral     Processor | Repositorie | s            |             |
| Processor     Beset Cor  |             |              |             |
| Heset Lor                | icol        |              |             |
|                          |             |              |             |
| 🖻 - Utility              |             |              |             |

Figure 40 IP catalog

The PLB\_EMC controller is available in the Memory controller directory. This module supports data transfers between the Processor Local Bus (PLB) and external synchronous and asynchronous memory devices.

The PLB EMC provides an interface between the PLB and one to four external banks of memory components.

The EMC supports PLB data bus widths of 8, 16, 32 & 64 bits, and memory subsystem widths of 8,16, 32 & 64 bits. It supports the PLB V3.4 byte enable architecture. Any access size up to the width of the PLB data bus is permitted. This kind of controller can perform data-width matching meaning when the width of the memory is less than the width of the PLB, multiple memory cycles are performed to transfer the data width of the bus if data-width matching has been enabled for that memory bank.

The PLB EMC provides basic read/write control signals and the ability to configure the access times for read, write, and recovery times when switching from read to write or write to read.

Figure 42 illustrates the top Level block diagram of the PLB EMC.



Figure 41 PLB top-level block diagram

The PLB EMC supports up to 4 banks memory. Each bank of memory has its own independent base address and address range. The address range of a bank of memory is restricted to be a power of 2. If the desired address range is represented by 2n, then the *n* least significant bits of the base address must be 0. For example, a memory bank with an addressable range of 4Mbytes ( $2^{22}$ ) could have a base address of 0x00400000 and a high address of 0x7FFFFF. In this design, base address of the PLB EMC was 0x00000000.

Memory can be accessed through the EMC as one of four types: byte (8 bits), half word (2 bytes), word (4 bytes), and double word (8 bytes). From the point of view of the PLB, data is organized as big-endian.

The PLB EMC does not provide a clock output to any synchronous memories. The PLB clock should be routed through an output buffer to provide the clock to the synchronous memories. To synchronise the synchronous memory clock to the internal FPGA clock, the FPGA system design should include a DCM external to the PLB EMC core that uses the synchronous memory clock input as the feedback clock as shown in **Figure 43**.



#### Figure 42 synchronous memory clocked by FPGA output with feedback

The three primary considerations for connecting the controller to memory devices were the width of the PLB data bus, the width of the memory subsystem, and the number of memory devices used. The width of the memory subsystem was simply the maximum width of data that was able to be read from or written to the memory subsystem.

The data and address signals at the memory controller are labelled with big-endian bit labelling (for example, D(0:31), D(0) is the MSB), whereas most memory devices are either Endian agnostic (they can be connected either way) or little-endian D(31:0) with D(31) as the MSB.

Most asynchronous memory devices only use Mem\_CEN, while most synchronous memory devices use both Mem\_CEN and Mem\_CE. Mem\_CEN is a function of the address decode while Mem\_CE is a function of the state machine logic.

The following **Table 12** shows the correct mapping of memory controller pins to memory device pins. Only one ZBT bank was implemented in this design but all of them were tested.

| EMC signals (MSB LSB)          | Memory device signal<br>(MSB LSB) | Comment                   |
|--------------------------------|-----------------------------------|---------------------------|
| ppc2zbt_Mem_DQ_pin (0 : 15)    | DQ(15:0)                          | Data Input and Output pin |
| ppc2zbt_Mem_Mem_A_pin (0 : 20) | A(20:0)                           | Address                   |
| ppc2zbt_Mem_BEN_pin (0 to 1)   | BW(1:0)                           | Byte write inputs         |
| ppc2zbt_Mem_CEN_pin (0 to 0)   | /CS1                              | Chip select (/CS1)        |
| ppc2zbt_Mem_OEN_pin (0 to 0)   | /OE                               | Output enable             |
| ppc2zbt_Mem_CE_pin             | CS2                               | Chip select (CS2)         |
| ppc2zbt_Mem_ADV_LDN_pin        | ADV                               | Address advance           |
| ppc2zbt_Mem_LBON_pin           | /LBO                              | Burst mode control        |
| ppc2zbt_Mem_WEN_pin            | /WE                               | Read/Write control input  |
| ppc2zbt_Mem_mem_Zz_pin         | ZZ                                | Power sleep mode          |
| ppc2zbt_Mem_CE2_pin            | /CS2                              | Chip select (/CS2)        |
| ppc2zbt_Mem_CKEN_pin           | /CKE                              | Clock enable              |

#### Table 11 connexion between EMC and ZBT memory

A timing constraint should be placed on the system clock, setting the frequency to meet the bus timing requirements. No external pullups/pulldowns were available on the MEM\_DQ signals onto the board, so pullup or pulldown resistors in the UCF file must be specified.

#### **1.5.3.3** Hardware implementation

One of the key advantages of using the Xilinx IP core is to have a design that only utilizes the resources required by the system and runs at the best possible performance.

Before testing the external memory controller, certain feature must be configured such as the memory data width, the memory address width, the base address, the external port connexion.

**Figure 44** shows every peripheral implemented in this design. The PLB\_EMC called "ZBT\_2Mx16bit" was connected onto the PLB bus and two others blocks were added to this XPS project: busAddr\_split\_0 and INST\_DCM\_TOMEM.

| P O<br>L P              | Filters<br>© Bus Interface 		Ports 		Addresse | es 🛐 🕶 Filter: | s (Applied) |                   |
|-------------------------|-----------------------------------------------|----------------|-------------|-------------------|
| BB                      | Name                                          | Mastership     | IP Version  | IP Classification |
|                         | і → ррс405_0                                  |                | 1.01.a      | PROCESSOR         |
| <b>▶</b> ∲— <u></u>   – |                                               |                | 1.01.a      | PROCESSOR         |
| │ │ │ │ ┝┿━━            | ian <b>⊘</b> pb                               |                | 1.02.a      | BUS PLB           |
|                         | 😥 🗢 opb                                       |                | 1.10.c      | BUS OPB           |
|                         | 🕀 🗢 reset_block                               |                | 1.00.a      | PERIPHERAL        |
|                         | 🗊 🗢 plb2opb                                   |                | 1.01.a      | PERIPHERAL        |
|                         | 👜 🗢 LEDS                                      |                | 3.01.Б      | PERIPHERAL        |
| ← •                     | 🗊 🗢 plb_bram_if_cntlr_1                       |                | 1.00.b      | PERIPHERAL        |
| ▶                       | 🗊 🗢 plb_bram_if_cntlr_1_bram                  |                | 1.00.a      | PERIPHERAL        |
|                         | 📄 🗢 dcm_0                                     |                | 1.00.Ь      | PERIPHERAL        |
|                         | 🗊 🗢 INST_DCM_TOMEM                            |                | 1.00.Ь      | PERIPHERAL        |
| K K                     | 🗊 🗢 jtagppc_cntlr_0                           |                | 2.00.a      | PERIPHERAL        |
|                         | 🗊 🧇 busAddr_split_0                           |                | 1.00.a      | PERIPHERAL        |
| <u> </u>                | 🔃 🗢 ZBT_2Mx16bit                              |                | 2.00.a      | PERIPHERAL        |

Figure 43 system assembly view for ZBT design

Only one bank was enabled (C\_NUM\_BANKS\_MEM=1) in this external memory controller with a maximum width of the memory device equal to 16 bit (C\_MAX\_MEM\_WIDTH=16). This example did not include support for PLB burst and cacheline transactions. The data-width matching option was checked in order to execute multiple memory access cycles to match width of Memory Bank 0 data bus to PLB data bus. The width of memory Bank0 data bus was set to 15 bit.

The ZBT memory provided a width of data bus of 18 bit but only 15 bit was used in this example. Finally, clock period was defined to 10000ps.

A DCM was configured according to the clock management **Figure 44**. This Digital Clock Manager DCM was called "INST\_DCM\_TOMEM".

This DCM provided an output clock called "ppc2zbt\_Mem\_k" that was running at 100MHz. This signal was linked to ZBT clock. The feedback clock input was connected to the synchronous memory clock that was provided by the memory" ppc2zbt\_Mem\_k\_fb".

The EMC provided width of memory Bank0 address bus of 32 bit. But the ZBT memory had only 21 bit address inputs. The **Table 13**.

| EMC signals(MSB LSB)         | Memory device signal (MSB LSB) |
|------------------------------|--------------------------------|
| ppc2zbt_Mem_Mem_A( 10 to 30) | ppc2zbt_Mem_Mem_A(20 to 0)     |

#### Table 12 address bus connexion

A Utility Bus Split core provided by Xilinx was used. It allowed user to split a bus into smaller buses. This component was called "busAddr\_split\_0".

This core took one input bus and splits it into two output buses and serves as glue logic between peripherals. **Figure 45** illustrates the block diagram of the "busAddr\_split\_0" component.



#### Figure 44 utility bus split in a system

This block took the 32-bit signal from the EMC (ppc2zbt\_Mem\_Mem\_A\_split) and provided a 21-bit signal to external memory (ppc2zbt\_Mem\_Mem\_A).

The PowerPC was connected to the ZBT SRAM saccording to the following Table 14.

| EMC signals(MSB LSB)    | Memory device signal (MSB LSB) |  |  |  |  |
|-------------------------|--------------------------------|--|--|--|--|
| ppc2zbt_Mem_DQ(0 to 15) | pppc2zbt_Mem_DQ(15 to 0)       |  |  |  |  |

#### Table 13 data bus connexion

So, the most significant bit of the memory device (pppc2zbt\_Mem\_DQ(17 to 16)) have not been connected. **Figure 46** illustrates the system assembly view of this design.

| Name                         | Net                     | Direction | Clas: Sensitivity | Range                       | Frequency | Reset Polari | IP Type          | IP Version |
|------------------------------|-------------------------|-----------|-------------------|-----------------------------|-----------|--------------|------------------|------------|
| External Ports               |                         |           |                   |                             |           |              |                  |            |
| 🕀 🗢 ppc405_0                 |                         |           |                   |                             |           |              | ppc405_virtex4   | 1.01.a     |
| 🕀 🗢 ррс405_1                 |                         |           |                   |                             |           |              | ppc405_virtex4   | 1.01.a     |
| 🖶 - 🗢 plb                    |                         |           |                   |                             |           |              | plb_v34          | 1.02.a     |
| 🗊 🗢 opb                      |                         |           |                   |                             |           |              | opb_v20          | 1.10.c     |
| 🗊 🗢 plb2opb                  |                         |           |                   |                             |           |              | plb2opb_bridge   | 1.01.a     |
| 🖶 🗢 LEDS                     |                         |           |                   |                             |           |              | opb_gpio         | 3.01.b     |
|                              |                         |           |                   |                             |           |              | plb_bram_if_cntl | lr 1.00.b  |
| 🕀 🗢 jtagppc_cntlr_0          |                         |           |                   |                             |           |              | jtagppc_cntlr    | 2.00.a     |
| — →ZBT_2Mx16bit              |                         |           |                   |                             |           |              | plb_emc          | 2.00.a     |
| Mem_A                        | ppc2zbt_Mem_Mem_A_split | 0         |                   | [0:(C_PLB_AWIDTH-1)]        |           |              |                  |            |
| Mem_DQ                       | ppc2zbt_Mem_DQ          | 10        |                   | [0:(C_MAX_MEM_WIDTH-1)]     |           |              |                  |            |
| -Mem_CEN                     | ppc2zbt_Mem_CEN         | 0         |                   | [0:(C_NUM_BANKS_MEM-1)]     |           |              |                  |            |
| Mem_OEN                      | ppc2zbt_Mem_OEN         | 0         |                   | [0:(C_NUM_BANKS_MEM-1)]     |           |              |                  |            |
| -Mem_WEN                     | ppc2zbt_Mem_WEN         | 0         |                   |                             |           |              |                  |            |
| -Mem_QWEN                    | No Connection           | 0         |                   | [0:((C_MAX_MEM_WIDTH/8)-1)] |           |              |                  |            |
| -Mem_BEN                     | ppc2zbt_Mem_BEN         | 0         |                   | [0:((C_MAX_MEM_WIDTH/8)-1)] |           |              |                  |            |
| Mem_RPN                      | No Connection           | 0         |                   |                             |           |              |                  |            |
| Mem_CE                       | No Connection           | 0         |                   | [0:(C_NUM_BANKS_MEM-1)]     |           |              |                  |            |
| Mem_ADV_LDN                  | No Connection           | 0         |                   |                             |           |              |                  |            |
| Mem_LBON                     | No Connection           | 0         |                   |                             |           |              |                  |            |
| Mem_CKEN                     | No Connection           | 0         |                   |                             |           |              |                  |            |
| -Mem_RNW                     | No Connection           | 0         |                   |                             |           |              |                  |            |
| Mem_DQ_I                     | No Connection           | 1         |                   | [0:(C_MAX_MEM_WIDTH-1)]     |           |              |                  |            |
| -Mem_DQ_0                    | No Connection           | 0         |                   | [0:(C_MAX_MEM_WIDTH-1)]     |           |              |                  |            |
| Mem_DQ_T                     | No Connection           | 0         |                   | [0:(C_MAX_MEM_WIDTH-1)]     |           |              |                  |            |
| 🕀 🧼 reset_block              |                         |           |                   |                             |           |              | proc_sys_reset   | 1.00.a     |
| 🖶 🗢 plb_bram_if_cntlr_1_bram |                         |           |                   |                             |           |              | bram_block       | 1.00.a     |
| 🕀 🗢 dcm_0                    |                         |           |                   |                             |           |              | dcm_module       | 1.00.a     |
| INST_DCM_TOMEM               |                         |           |                   |                             |           |              | dcm_module       | 1.00.a     |
| 😑 🗢 busAddr_split_0          |                         |           |                   |                             |           |              | util_bus_split   | 1.00.a     |
| Sig                          | ppc2zbt_Mem_Mem_A_split | 1         |                   | [0:C_SIZE_IN-1]             |           |              |                  |            |
| Out1                         | ppc2zbt_Mem_Mem_A       | 0         |                   | [C_LEFT_POS:C_SPLIT-1]      |           |              |                  |            |
| Out2                         | No Connection           | 0         |                   | [C_SPLIT:C_SIZE_IN-1]       |           |              |                  |            |

#### Figure 45 system assembly view for the ZBT design

 Table 15 describes the memory map of this application.

| Device         | Add        | ress       | Size | Comment    |
|----------------|------------|------------|------|------------|
|                | Min        | Max        |      |            |
| PLB_BRAM_CNTLR | 0xFFFFC000 | 0xFFFFFFFF | 16K  | PLB Memory |
| OPB_GPIO       | 0x10000000 | 0x100003FF | 1K   | LED output |
| PLB2OPB        | 0x10000000 | 0x100003FF | 1K   | Bridge     |
| ZBT_2Mx16bit   | 0x0000000  | 0x003FFFFF | 4Mb  | PLB_EMC    |

Table 14 memory map for the ZBT design

**Figure 47** describes the hardware implemented. The block PLB EMC is available onto the PLB bus.



#### Figure 46 block diagram ZBT design

With this configuration, the PLB\_EMC required 370 slices in spite of the PLB\_ EMC block included the external ZBT memory controller and the PLB IPIF as shown the **Figure 15**.

The next section describes the software application.

#### 1.5.3.4 Software implementation

The configuration of the BSP was the same that defined in the first design. Software application was implemented to test the external memory.

The Library Generator tool, Libgen, generated several folders which contain C header files needed by drivers, libraries and MAKE files needed to compile the OSs, libraries, and drivers.

In this project, the include file xutil.h was also created through Libgen. This file contained function prototypes such as memory test function. They were used to test the ZBT memory. Here are three function prototypes used in this application.

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

#### Figure 47 Xutil\_memtest prototypes

These functions allowed users to access the memory as one of three types: byte (XUtil\_MemoryTest8), half word (XUtil\_MemoryTest16), word (XUtil\_MemoryTest32). Every function took four parameters. "Addr" was a pointer to the region of memory to be tested. The "Words" parameter was the length of the block. The next one was the constant used for the constant pattern test and "Subtest" parameter was the test selected. A subset of the memory tests could be selected or all of the tests could be run in order. The detailed description of the subtest is available **Table 16**.

If there was an error detected by a subtest, the test stopped and the failure code was returned. Further tests were not run even if all of the tests were selected.

| Type Definitions | description of the subtest                               |
|------------------|----------------------------------------------------------|
| XUT_ALLMEMTESTS  | Ran 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 = 0x0000001$                                 |
|                  | location $2 = 0x0000002$                                 |
|                  |                                                          |
|                  | Walking Zero's Test. This test uses the inverse value    |
|                  | of the walking ones test as the test value for memory.   |
| XUT_WALKZEROS    | location $1 = 0xFFFFFFE$                                 |
|                  | 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".                      |

#### Table 15 memory test descrption

The software application specified in Application tab. The TestApp\_pheripheral.c file used Xilinx's libraries to test the memory and the GPIO peripherals. The file "xgpio\_tapp\_example.c" contained an example for using GPIO hardware and driver. The source code "testApp\_ZBT.c" used GPIO hardware and driver to display the result of this test on the GPIO LED.

Figure 49 shows the software application selected for this implementation.



Figure 48 software application design ZBT

Next step was the validation of this implementation using the application code described above.

#### 1.5.3.5 Test and validation

Before running the application, every parameter of function prototypes have to be initialised. The "Addr" parameter to the base address of the ZBT\_2Mx16bit controller. All subtests can be run by setting "subtest" parameter to XUT\_ALLMEMTESTS type. The "Words" parameter defined length of the memory. Thus, this element is different for every function. One of three types could be performed: 8bitx4MB (Words=4x1024x1024), 16bitx2MB (Words=2x1024x1024) and 32bitx1MB (Words=1x1024x1024). Finally, the "pattern" parameter was initialised to 0xA5.

This test was performed in in debug mode as shown the Figure 50.

| antik mentent a 🖓                                                                                               | Senten Min | <b>1</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                           | - 3 🗄 👗        | E LICHTY HIGH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                       |                   |
|-----------------------------------------------------------------------------------------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-------------------|
| the first from the second                                                                                       | -          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |                | 111000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |                   |
| 4 10 10 10 10                                                                                                   | 0 P        | 2 A # 6 # -2 8 Fin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1:                        | र्वन के स      | Kane                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Value                                 |                   |
| xutil_mentest.c                                                                                                 | -          | 30til_HemoryTest32 -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                           | SOURCE -       | BAddr<br>Vords<br>Pattern                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | (Xuint32 *) 8x8<br>1824<br>2863289685 |                   |
| 117                                                                                                             |            | = #L; i < Words; i++)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           | -              | Subtest                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | B "\0"                                |                   |
| 119                                                                                                             | 4 Ad       | dr[i] - Val:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                           | -              | j<br>Ual                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | A294967295<br>1825                    |                   |
| 121                                                                                                             |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |                | World                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 8                                     |                   |
| 122                                                                                                             | /-         | write memory location */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                           |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                       |                   |
| 124                                                                                                             | Va         | 1**:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                           |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                       |                   |
| 125                                                                                                             | 3          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |                | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                       |                   |
| 126                                                                                                             | 1.         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |                | d Menure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                       | - 0               |
| 128                                                                                                             |            | tore the reference 'Ual' to th                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                           |                | and a sure of the |                                       |                   |
| 129                                                                                                             |            | tial value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                           |                | Address (0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                                     | Target is IIII er |
| 138                                                                                                             | •/         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |                | Marris Jo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                       | ASCII             |
| 132                                                                                                             | 842 -      | Flestwals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                           |                | 8x 80000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 8×888888901                           |                   |
| 133                                                                                                             |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |                | 8x 04000084                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x80000001                            |                   |
| 134                                                                                                             | 1.         | the second s |                           |                | exappointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bx 808888887                          |                   |
| 135                                                                                                             | • the      | ck every word within the Words                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                           | -              | 0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 8x 80000004                           |                   |
| rogram stopped at line 112                                                                                      | p.,        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           | Bxffffc924 132 | 0x 00000010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x00800005                            |                   |
| A CONTRACTOR OF |            | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                           |                | 0x88000014                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 8x80000006                            |                   |
| Coversition of the                                                                                              |            | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                           | ms 💷 🔣         | 0x00000018                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Bx 80800007                           |                   |
| white connections                                                                                               | ble in c   | inpatibility node.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <ul> <li>Wetch</li> </ul> |                | Exagonatic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0000008                             |                   |
| NLO:WD1 - Usamula                                                                                               | tion: Se   | lected Device 1 for debugging.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Nane                      | Value          | 0x88088828                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x00000009                            |                   |
| TAG chain config                                                                                                | iration    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Addr(8)                   | 1              | Rx88008824                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 8×000008.                             |                   |
| evice ID Code                                                                                                   | 1          | 8 Length Part Mane                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Addr[1]<br>Addr[2]        | 2              | 8×88888828                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 8x8888888                             |                   |
| I. Hiebdiry3                                                                                                    |            | 14 XC499X68                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Addr[3]                   | A I            | 0x8008882c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0×0000000c                            |                   |
| D: Connected to                                                                                                 | PowerPC    | target. Processor Version Ho<br>sing special PowerPC features                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | sddr[4]                   | 5              | 0x00000030                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 8×00000000                            |                   |
| I-Cache (Data                                                                                                   | or acces   | sing special PowerPC Features .<br>sabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Addr[5]                   | -              | Rx 00000034                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x00000000                            | ****              |
| I-Gache (Lag)                                                                                                   | : Di       | pabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Addr[7]                   | 8              | Bx 80000038                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0000000f                            |                   |
| D-Cache (Bata<br>D-Cache (Tau)                                                                                  |            | abled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0ddr[8]                   |                | Bx8888883c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 8×00880010                            | inte              |
| 1SOCH<br>TLB                                                                                                    | 1 Di       | iabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | .0ddr191                  |                | Bx88000040                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x00800011                            |                   |
| DCR                                                                                                             |            | ahled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |                | Bx 88008844                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ex00000012                            | ++++              |
| mnected to "ppc                                                                                                 | " target   | 14 - 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                           |                | Bx 00000048                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x00000013                            | ****              |
| arting GDB serv                                                                                                 | er for "   | ppc" target (id - 0) at TCP po                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Data D                    | written to     | 8x000004c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 8x80888814                            |                   |
| cepted a new GD                                                                                                 | E connec   | tion from 127.8.8.1 un part 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 2                         |                | Rx 8008885 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8x00000015                            |                   |
| reset to Bafff                                                                                                  | ffffe, G   | learing MSR Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | the m                     | the memory     | 8x88888854                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Ex 80888816                           |                   |
|                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |                | ex 00000059                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x00000017                            | ****              |
|                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | •                         | 19             | 0x0000005c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x00888018                            |                   |
|                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Set 1                     | 1.000          | 8x8000060                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 8×00000019                            |                   |
|                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1                         | Add Watch      | 9x88888864                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0000001a                            |                   |

Figure 49 XMD debugger - ZBT design

An application is also available in stand alone. The following paragraph illustrates an example implementing a memory cache, com-port link and increasing the PowerPC clock frequency.

#### 1.5.4 Global implementation

The data on-chip memory (DOCM), the instruction on-chip memory (IOCM), data and instruction cache and internal memory were connected to the PowerPC according the requirements. The PowerPC clock frequency was increased as well. In order to provide a full firmware, two Comport links were added to this design.

#### **1.5.4.1** Hardware implementation

According to the requirements, different kinds of memories were implemeted. These memories used a specific communication resource.

**Figure 51** shows every peripheral implemented in this design. Both of ZBT memories were implemented in this design.

| P O<br>L P                                            | 0<br>C        | - Filters<br>⊕ ⊙ Bus Interface ○ Ports | O Addresses           | ∰v Filters (Applied | ŋ          |
|-------------------------------------------------------|---------------|----------------------------------------|-----------------------|---------------------|------------|
| B B                                                   | й             | Name                                   | <b>Bus Connection</b> | IP Type             | IP Version |
| <u> </u>                                              | -             | 🗊 🗢 ррс405_0                           |                       | ppc405_virtex4      | 1.01.a     |
| ¢—                                                    | —ġ—           | 🗐 🗢 ppc405_1                           |                       | ppc405_virtex4      | 1.01.a     |
|                                                       |               | 🖨 🧼 iocm                               |                       | isocm_v10           | 2.00.Б     |
|                                                       |               | 📮 🧼 docm                               |                       | dsocm_v10           | 2.00.Б     |
|                                                       |               | 🚊 🗢 🎝                                  |                       | plb_v34             | 1.02.a     |
|                                                       |               | 🗐 🧼 opb                                |                       | opb_v20             | 1.10.c     |
| <del>K K</del>                                        |               | 🗊 🗢 jtagppc_0                          |                       | jtagppc_ontlr       | 2.00.a     |
|                                                       |               | 🗄 🗢 reset_block                        |                       | proc_sys_reset      | 1.00.a     |
| f f                                                   |               | 🔁 🗢 ioc.m_cntlr                        |                       | isbram_if_ontlr     | 3.00.Б     |
| Þ-Þ-Þ                                                 | - <b>þ</b> Þ- | 🗄 🗢 isocm_bram                         |                       | bram_block          | 1.00.a     |
|                                                       | - K           | 🗉 🧼 docım_cntli                        |                       |                     | 3.00.Б     |
| Þ-Þ-Þ                                                 | -Þ-+          | 🗄 🗢 dsocm_bram                         |                       | bram_block          | 1.00.a     |
|                                                       |               | 🗉 🗢 plb2opb                            |                       | plb2opb_bridge      | 1.01.a     |
|                                                       |               | 🔁 🗢 LEDS                               |                       | opb_gpio            | 3.01.Б     |
|                                                       |               | 🔒 🗢 plb_bram_it_cntlr_1                |                       | _plb_bram_if_cntli  | 1.00.Б     |
|                                                       |               | 🐵 🗢 plb_bram_it_cntlr_1_bran           | :                     | bram_block          | 1.00.a     |
|                                                       |               | 🗄 🧼 dcm_0                              |                       | dcm_module          | 1.00.Ь     |
|                                                       |               | 🗄 🗢 plb_bram_it_cntlr_2                |                       | _plb_bram_if_cntli  | 1.00.Б     |
| i <b>⊳ i k</b> i bi i i i i i i i i i i i i i i i i i | -ṗṗ-          | 🐵 🗢 plb_bram_it_cntlr_2_bran           | :                     | bram_block          | 1.00.a     |
| K   •                                                 |               | 🕂 🔁 🗢 plb_bram_il_cntlr_3              |                       | _plb_bram_if_cntli  | 1.00.Б     |
| · ▶ Þ Þ – Þ – Þ                                       | -ò            | 🐵 🗢 plb_bram_it_cntlr_3_bran           | :                     | _                   | 1.00.a     |
|                                                       |               | 🗄 🧼 DCM_ZBT_bankA                      |                       | dcm_module          | 1.00.Ь     |
|                                                       |               | 🗊 🧼 DCM_ZBT_bankB                      |                       | dcm_module          | 1.00.Ь     |
|                                                       |               | 🗈 🗢 busAddr_split_0                    |                       | util_bus_split      | 1.00.a     |
|                                                       |               | 🗉 🧼 busAddr_split_1                    |                       | util_bus_split      | 1.00.a     |
|                                                       |               | 🔁 🗢 ZB T_2Mx16bit                      |                       | plb_emc             | 2.00.a     |
| <b>è</b>                                              |               | <u>⊞</u> - <i>≪ZBTB_2Mx</i> 16bit      |                       | plb_emc             | 2.00.a     |

Figure 50 system assembly view - two ZBT memory banks

The docm\_cntlr connected BRAM block to the data side on chip memory (DSOCM) bus in PowerPC 405 based embedded systems. The DOSCM block was a data-side On-chip Memory (OCM) bus interconnect core. The core connected the PowerPC data-side OCM interface to data-side OCM BRAM controller (docm\_cntlr). The same architecture was implemented for the instruction-side on chip memory. The iocm\_cntlr connected BRAM block to the instruction side on chip memory (ISOCM) bus. The IOCM component was an instruction side On-chip Memory bus interconnect core.

In this design the PowerPC was running at 300MHz and every peripheral was clocked at 100MHz. **Figure 52** shows the clock management. The "DCM\_0" component generated two clocks: the system clock (sys\_clk\_s) at 100 MHz and the processing clock (proc\_clk\_s) was running at 300 MHz.



Figure 51 clock management global design

**Table 18** describes the memory map of this design. In this design, 108Kb on chip memory were connected to the PowerPC. This processor also supported data transfer between the PLB bus and the 8Mb of external ZBT memory. The memory map shows that the internal memory and the external memory have consecutive addresses according to DIAMOND specification.

| Device           | Address    |            | Size | Comment    |
|------------------|------------|------------|------|------------|
|                  | Min        | Max        |      |            |
| PLB_BRAM_CNTLR   | 0x00FF0000 | 0x00FFFFFF | 64Kb | PLB Memory |
| OPB_GPIO         | 0x40000000 | 0x4000FFFF | 64Kb | LED output |
| PLB2OPB          | 0x40000000 | 0x4000FFFF | 1Kb  | Bridge     |
| ZBT_2Mx16bit     | 0x01000000 | 0x013FFFFF | 4Mb  | PLB_EMC    |
| ZBTB_2Mx16bit    | 0x01400000 | 0x017FFFFF | 4Mb  | PLB_EMC    |
| IOCM_CNTLR       | 0xFFFFc000 | 0xFFFFFFFF | 16Kb | ISOCM      |
| DOCM_CNTLR       | 0xA0008000 | 0xA000BFFF | 16Kb | DSOCM      |
| PLB_BRAM_CNTLR_2 | 0x0000000  | 0x00000FFF | 4Kb  | Dcache     |
| PLB_BRAM_CNTLR_3 | 0x00001000 | 0x00001FFF | 4Kb  | Icache     |

Table 16 memory map global design

**Figure 53** describes the hardware implemented. Both external ZBT memory controllers were connected onto the PLB bus. Both memories connected onto the On-chip memory bus appear above the PowerPC. This Figure allowed you to check every memory connected onto the PLB bus



#### Figure 52 block diagram global design

This design used 5 percents of slices. More than 4 percents slices are used by the PLB controller and the PLB/OPB bridge. The design flow was generated by XPS.

#### **1.5.4.2** Software implementation

The software application developed in the previous design was improved to test every memory.

In this application, every memory was tested singly and then all memories were tested in the same time as shown in **Figure 54**.

```
#include "xutil.h"
//(plb_bram_if_cntlr_1) - internal memory
#define MemorySize_I1 (XPAR_PLB_BRAM_IF_CNTLR_1_HIGHADDR - XPAR_PLB_BRAM_IF_CNTLR_1_BASEADDR)+1
//external Memory (ZBT_2Mx16bit) - external memory
#define MemorySize_EA (XPAR_ZBT_2MX16BIT_MEMO_HIGHADDR - XPAR_ZBT_2MX16BIT_MEMO_BASEADDR)+1
#define MemorySize_EB (XPAR_ZBT_2MX16BIT_MEMO_HIGHADDR - XPAR_ZBT_2MX16BIT_MEMO_BASEADDR)+1
//all of them
#define MemorySize (MemorySize I1 + MemorySize EA + MemorySize EB)
//========
  // Testing internal and external Memory (plb bram if cntlr 1 - ZET 2Mx16bit - ZETE 2Mx16bit) - external memory
 Size=MemorySize;
 status=XUtil MemoryTest32((Xuint32*)XPAR PLB BRAM IF CNTLR 1 BASEADDR, (Size/4), OxAAAA5555,XUT ALLMEMTESTS);
 if(status==0)value=0x1; else value=0x0;
 status=XUtil MemoryTest16((Xuint16*)XPAR PLB BRAM IF CNTLR 1 BASEADDR,(Size/2) , OxAA55,XUT ALLMEMTESTS);
 if(status==0)value=(0x2 | value); else value=value;
 status=XUtil MemoryTest8((Xuint8*)XPAR PLB BRAM IF CNTLR 1 BASEADDR,(Size), 0xA5, XUT ALLMEMTESTS);
 if(status==0)value=(0x4 | value); else value=value;
 status = displayLed(XPAR_LEDS_DEVICE_ID,3,value);
 value =0;
```

#### Figure 53 test internal - external memories

Another project implementing the Comport 2 to the PowerPC was created. The architecture was the same with the Comport 3 but just the top level into Xilinx ISE changed in order to reset this link to the output. Thus, the PowerPC can be connected to another processor via two comport links starting off in two different electrical states: Comport 3 in input and Comport 2 in output.

# CONCLUSION

Sundance provides a design that implemented a PowerPC with different kind of memories such as data and instruction memories connected onto On-chip memory bus, data and instruction cache and internal memory interfaced to the PLB bus. Two separate ZBT memory banks were also connected to the PowerPC. This design contained an internal memory and external memories with consecutive addresses. The processor had more than 8MB of memories available.

This design allows users to interface the PowerPC to another processor such as a DSP. For this design, another board was required.

Several improvements could be done such as interrupt support and DMA in the user peripheral. These options can be added to the user peripheral in the IPIF service.

# References

- [1] Sundance Multiprocessor Technology Ltd, URL: http://www.sundance.com
- [2] 3L DIAMOND, URL: http://www.3l.com
- [3] Xilinx Inc, URL: <u>http://www.xilinx.com</u>
- [4] Texas Instruments, URL: <u>http://focus.ti.com/dsp/docs/dsphome.tsp?sectionId=46</u>
- [5] IBM CoreConnect architecture, URL: <u>http://www-03.ibm.com/chips/products/coreconnect/</u>
- [6] Samsung ZBT memory, URL: <u>http://www.samsung.com/</u>
- [7] Texas Instrument, URL: <u>http://focus.ti.com/docs/toolsw/folders/print/ccstudio.html</u>
- [8] Xilinx application notes, URL: <u>http://www.xilinx.com/xlnx/xweb</u>

# Glossary

| Acronym        | Definition                                                                                                                                                                                                                     |  |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| BRAM           | Block Random Access Memory                                                                                                                                                                                                     |  |  |
| DCM            | Digital clock Manager                                                                                                                                                                                                          |  |  |
| DMA            | Direct Access Memory                                                                                                                                                                                                           |  |  |
| DSP            | Digital Signal Processor                                                                                                                                                                                                       |  |  |
| FIFO           | First In First Out (memory)                                                                                                                                                                                                    |  |  |
| FIRMWARE       | Firmware is data that sets programmable logic into a state<br>where it implements a particular hardware design. It starts as<br>a textual description of an electronic circuit which is<br>processed to produce a binary file. |  |  |
| FPGA           | Field Programmable Gate Array                                                                                                                                                                                                  |  |  |
| FPU            | Floating Point Unit                                                                                                                                                                                                            |  |  |
| Gb             | Gigabits                                                                                                                                                                                                                       |  |  |
| GB             | Gigabytes                                                                                                                                                                                                                      |  |  |
| ISE            | Integrated System Environment                                                                                                                                                                                                  |  |  |
| LSB/MSB        | Less Significant Bit / Most Significant Bit                                                                                                                                                                                    |  |  |
| MIPS           | Mega Instructions Per Second                                                                                                                                                                                                   |  |  |
| MULTIPROCESSOR | A multiprocessor machine uses two or more CPUs for routine processing                                                                                                                                                          |  |  |
| NTSC           | National Television Standard Committee                                                                                                                                                                                         |  |  |
| OEM            | Original Equipment Manufacturer                                                                                                                                                                                                |  |  |
| OPB            | On-chip Peripheral Bus                                                                                                                                                                                                         |  |  |
| PAL            | Phase Alternation Line                                                                                                                                                                                                         |  |  |
| PCI            | Peripheral Component Interconnect                                                                                                                                                                                              |  |  |
| PPC            | PowerPC                                                                                                                                                                                                                        |  |  |
| RAM/ROM        | Read Access Memory / Read Only Memory                                                                                                                                                                                          |  |  |
| RTOS           | Real Time Operating Software                                                                                                                                                                                                   |  |  |
| SDB            | Sundance Digital Bus                                                                                                                                                                                                           |  |  |
| SHB            | Sundance High-speed Bus                                                                                                                                                                                                        |  |  |
| SDRAM          | Synchronous Dynamic Random Access Memory                                                                                                                                                                                       |  |  |
| SMT            | Sundance Multiprocessor Technology                                                                                                                                                                                             |  |  |
| TI             | Texas Instruments                                                                                                                                                                                                              |  |  |
| TIM            | Texas Instruments Module: a form factor board format                                                                                                                                                                           |  |  |
| VHDL           | Very High-speed integrated circuit Hardware Description Language                                                                                                                                                               |  |  |
| YCrCb          | luminance, red chrominance, blue chrominance (video format)                                                                                                                                                                    |  |  |
| ZBT            | Zero Bus Turnaround                                                                                                                                                                                                            |  |  |