#### Gaisselquist Technology, LLC

#### REAL-TIME CLOCK SPECIFICATION

Dan Gisselquist, Ph.D. dgisselq@opencores.org

May 26, 2015

Copyright (C) 2015, Gisselquist Technology, LLC

This project is free software (firmware): you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WAR-RANTY; without even the implied warranty of MERCHANTIBILITY or FITNESS FOR A PAR-TICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see <a href="http://www.gnu.org/licenses/">http://www.gnu.org/licenses/</a>; for a copy.

#### **Revision History**

| Rev. | Date      | Author      | Description |
|------|-----------|-------------|-------------|
| 0.1  | 5/25/2015 | Gisselquist | First Draft |

#### Contents

#### Page

| 1 | Introduction       | 1 |
|---|--------------------|---|
| 2 | Architecture       | 2 |
| 3 | Operation          | 3 |
| 4 | Wishbone Datasheet | 4 |
| 5 | I/O Ports          | 5 |

#### Tables

| Table |                    |      |      |      |      |  |      |  |  | Pa | age |
|-------|--------------------|------|------|------|------|--|------|--|--|----|-----|
|       |                    |      |      |      |      |  |      |  |  |    |     |
| 4.1.  | Wishbone Datasheet | <br> | <br> | <br> | <br> |  | <br> |  |  |    | 4   |

#### Preface

My thanks to those helpers on the Xilinx Forum who helped me get the final step to getting this working.

Dan Gisselquist, Ph.D.

#### Introduction

This core makes the ICAPE2 FPGA configuration registers available to be read or written from a wishbone bus. As the documentation of this capability could use a bit to be desired, I have put this file together to help document what works.

The interface itself is very valuable for a couple of purposes—from my humble and personal perspective. The first is the user configurable watchdog timer which can be used to automatically reset an FPGA after it locks up. The second is the warm boot start capability, which makes it possible to create a fall back configuration image and test it without compromising the ability of the FPGA to be started in a known good image. The third valuable capability is that of commanding a reconfiguration. All of these capabilities are available through this interface. Further details are available from Xilinx's "7-Series FPGAs Configuration" User Guide.

This introduction is the first chapter. Beyond this introduction, most of the capabilities are documented elsewhere. Hence, the register chapter will be omitted and the reader will be gently pointed to the User's Guide. This leaves the Wishbone chapter and the I/O Port's chapter which follow.

As always, write me if you have any questions or problems.

#### Architecture

If I understand correctly, every one of Xilinx's 7–Series FPGA's contains two ICAPE2 interface modules. These modules allow user logic to communicate with the configuration interface of the chip. This interface, however, isn't well documented. According to the User's Guide, it matches the SelectMAP interface, yet in practice ... it doesn't.

This core encapsulates the difficulty of matching that interface. Register addresses match those in the User's Guide, as do register definitions.

#### Operation

Consider the warm boot reload operation. To do this, write the address in configuration memory of an FPGA image to the warm boot start address (WBSTAR). In this case, that is address 5'h10 within this interface. A second write to the configuration command address (CMD), 5'h4 in this interface, will issue the IPROG command to the FPGA and cause it to configure itself from the address you just gave it.

There, wasn't that simple?

Now I can, from the comfort of my home, reconfigure an FPGA in my office without needing to press the power button or connect to a JTAG cable. Not bad, no?

#### Wishbone Datasheet

Tbl. 4.1 is required by the wishbone specification, and so it is included here. The big thing to notice

| Description                | Specification                   |
|----------------------------|---------------------------------|
| Revision level of wishbone | WB B4 spec                      |
| Type of interface          | Slave, Read/Write               |
| Port size                  | 32-bit                          |
| Port granularity           | 32-bit                          |
| Maximum Operand Size       | 32-bit                          |
| Data transfer ordering     | (Irrelevant)                    |
| Clock constraints          | See the Datasheet for your part |
|                            | Signal Name Wishbone Equivalent |
|                            | i_clk CLK_I                     |
|                            | i_wb_cyc CYC_I                  |
|                            | i_wb_stb STB_I                  |
| Signal Names               | i_wb_we WE_I                    |
| Signal Mames               | i_wb_addr ADR_I                 |
|                            | i_wb_data DAT_I                 |
|                            | o_wb_ack ACK_O                  |
|                            | o_wb_stall STALL_0              |
|                            | o_wb_data DAT_O                 |

Table 4.1: Wishbone Datasheet

is that this ICAPE2 interface acts as a wishbone slave, and that all accesses to the ICAPE2 registers become 32-bit reads and writes to this interface. Bit ordering is the normal ordering where bit 31 is the most significant bit and so forth. (Bit reversal is accomplished internally to match Xilinx's definition.) The o\_stall and o\_ack lines are necessarily used to deal with the fact that operations to the device take many clocks to complete (14 for writes, 21 for reads), so be prepared to wait a couple of clocks for your access to complete. Further, the o\_ack line will go high while the bus is stalled in many cases, indicating that the operation is complete but that the core is not yet ready to handle a subsequent request.

# I/O Ports

This core offers no I/O ports beyond those of the wishbone discussed in Chapt. 4. The I/O ports associated with the ICAPE2 interface are captured internally, and not brought to the output of this core.