Achronix® Data Acceleration

**Application Note** 

#### June 22, 2021

Introduction

A Speedster®7t FPGA is configured at startup using a supplied bitstream containing the user design and the configuration of the interface subsystems in the I/O ring within the FPGA. After this configuration stage, the FPGA enters user mode and begins to operate with the user design.

During operation, it can be necessary to subsequently access, and in some instances modify, the configuration registers of the I/O ring. This action is required to enable or disable channels, check status of a block, or to reconfigure to a new data rate or data format. Examples include:

- Memory controller training
- SerDes or PCS link-up
- PCle enumeration
- Bar support

To monitor the status and modify the configuration, the user design must have access to the subsystem configuration registers.

Within the Speedster device, the configuration and status registers (CSR) form part of the global address map. This map is detailed in "Chapter - 6: Speedster7t NoC Address Mapping" of the Speedster7t Network on Chip User Guide (UG089), and is broken down into particular memory spaces. These spaces can be accessed through a number of mechanisms. This application note describes how to access the global address map using the Speedster FPGA JTAG port, via the ACE Tcl console.

# Memory Map

Each device has its own global memory map. The following table details the memory map for Speedster AC7t1500 and AC7t1550 devices. The NoC uses the most significant bits (MSB) in the address to identify the destination space of a transaction. As can be see in the table below, there are several memory spaces, each performing a different function.

| Address<br>Bit | 41 | 40 | 39  | 38            | 37 | 36   | 35 | 34                                 | 33   | 32   | 31   | 30   | 29                | 28   | 27             | 26 | 25 | 24 | 23 | 22 |  | 0 |
|----------------|----|----|-----|---------------|----|------|----|------------------------------------|------|------|------|------|-------------------|------|----------------|----|----|----|----|----|--|---|
| Destination    |    |    |     |               |    |      |    |                                    |      |      |      |      |                   |      |                |    |    |    |    |    |  |   |
| PCle           | 1  | ID | Mei | emory Address |    |      |    |                                    |      |      |      |      |                   |      |                |    |    |    |    |    |  |   |
| DDR4           | 0  | 1  | Mei | emory Address |    |      |    |                                    |      |      |      |      |                   |      |                |    |    |    |    |    |  |   |
| GDDR6          | 0  | 0  | 0   | 0             | 0  | Ctrl | ID |                                    |      | Ме   | mory | Addı | ress              |      |                |    |    |    |    |    |  |   |
| NAP            | 0  | 0  | 0   | 1             | 0  | 0    | 0  | NAI                                | P Co | lumn |      | NA   | P Ro              | W    | Memory Address |    |    |    |    |    |  |   |
| CSR<br>Space   | 0  | 0  | 1   | 0             | 0  | 0    | 0  | 0 Target ID IP ID Memor<br>Address |      |      |      |      | Memory<br>Address |      |                |    |    |    |    |    |  |   |
| FCU            | 0  | 0  | 1   | 1             | 0  | 0    | 0  | 0                                  | 0    | 0    | 0    | 0    | FCI               | J Ad | dress          | 5  |    |    |    |    |  |   |

Table 1: AC7t1500 and AC7t1550 Global Address Map

## **Programming Mechanisms**

The Speedster device can be programmed using either a .hex file or a .jam file. However, in order to use the Tcl API (see page 6), the device must be programmed using a .hex file.

## Note

When designing a board with the Achronix Speedster FPGA, include an LED to monitor the FCU\_CONFIG\_USER\_MODE signal to ensure that the bitstream is properly downloaded to the device.

## Programming Using a .hex File

Speedster FPGA devices can be programmed using a .hex file by following these steps:

 Enter the Programming and Debug perspective in ACE using either the Programming and Debug Perspective toolbar icon as shown in the figure below or by selecting Window → Open Perspective → Programming and Debug.



Figure 1: The Programming and Debug Perspective Toolbar Icon

2. In the Tcl Console, enter the command jtag::get\_connected\_devices. The connected Speedster device ID is returned if the device is properly connected to the system.



#### Figure 2: Verifying the Connected Device

3. After verifying that the device is connected to the system, set the variable jtag\_id to the device ID returned by the jtag::get\_connected\_devices command as shown.



#### Figure 3: Setting the *jtag\_id* Variable to the ID of the Connected Device

4. (Optional) Open a JTAG connection with the device using the ac7t1500::open\_jtag command.



Figure 4: Opening a JTAG Connection

5. Download the .hex file to the device using the ac7t1500::program\_hex\_file <path to hex file> command. This command also automatically runs the open\_jtag command if the port is not already open making the preceding step optional.



Figure 5: Downloading a Bitstream to the AC7t1500ES0 Device

## Note

When a JTAG connection with the device is opened, it remains open until it is closed. It is not required to close and reopen a new connection before downloading a bitstream if the JTAG connection is already open.

6. Close the JTAG connection with the ac7t1500::close\_jtag command.



Figure 6: Closing the JTAG Connection

## Marning

There are two groups of commands that can be used to open and close the JTAG port. These are:

- 1. jtag::open
  - jtag::close
- 2. <device namespace>::open\_jtag
  - <device namespace>::close\_jtag
  - <device namespace>::program\_hex\_file

The <device\_namespace> commands use a static variable, jtag\_port\_open to track whether the JTAG port is already open. When the above commands are mixed, for example opening the port with jtag::open, and subsequently using ac7t1500::program\_hex\_file to program the device, the jtag\_port\_open variable goes out of sequence. The following error is reported:

Cannot open a new connection to FT5YI791. A JTAG connection to FT5YI791 is already open. Please call jtag::close to free up the connection.

To avoid this error, it is recommended that the above command groups are not mixed.

If this error occurs, it can be resolved with either of the following commands:

- jtag::close
- set jtag\_port\_open 1

The latter command, indicates to the <device namespace> commands that the JTAG port is already open.

## Programming Using a .jam File

Speedster FPGA devices can be programmed using a .jam file by following these steps:

1. Select the **Download** window in the **Programming and Debug** perspective.



Figure 7: Selecting the Download Window

2. Use the bitstream from the active implementation (default) or manually select the bitstream by clicking **Manual Selection**.

| 🅸 Snapshot Debugger 🗣 Download 🛱 🔟 JTAG Browser    | f | 000 |   |
|----------------------------------------------------|---|-----|---|
| ▼ STAPL Design File                                |   |     |   |
| Select the bitstream file (*.jam) to be used.      |   |     |   |
| STAPL Design File:                                 |   |     |   |
| O Default File from Current Design/Impl            |   |     |   |
| R Manual Selection Browse                          |   |     |   |
| C:\quickstart\src\ace\impl_1\output\quickstart.jam |   |     | ~ |

#### Figure 8: Manually Selecting a .jam File

3. Download the bitstream to the device by clicking the Run 'PROGRAM' button.



#### Figure 9: Downloading the Bitstream to the FPGA

## Note

All of the commands above refer to the AC7t1500 device and use the ac7t1500 namespace. When targeting the AC7t1550 device, it is necessary to change the namespace of the commands to ac7t1550. See below for namespace details.

# Tcl Register Dictionary

For access via JTAG, using the ACE Tcl console, ACE has a built in API with access mechanisms to each of the device memory areas.

## Namespaces

There is a specific Tcl namespace for the API to each device. Therefore each command listed below must be prefixed with its respective device namespace. For example, to read from a named register (see page 12) in the AC7t1500 device, the ac7t1500::csr\_read\_named command must be used and, likewise, to read from an AC7t1550 device named register, the ac7t1550::csr\_read\_named command must be used.

## **Dictionary Token Hierarchy**

The following explains how a very large memory space (2<sup>42</sup> bits) is broken down into logical areas, which are represented by tokens that can be used to navigate to an individual register.

The AC7t1500 and AC7t1550 use a unified memory space to include the following registers:

- Configuration and status registers (CSR)
- FPGA control unit (FCU) registers
- NoC access point (NAP) registers
- Registers providing access to the GDDR6, DDR4 and PCI memory areas

This 42-bit address can be accessed from many different locations, including from the FCU, the PCIe and from an individual NAP in the design.

The AC7t1500/AC7t1550 memory map, which uses the top address bits to divide the space into the major areas, is detailed below. A function description is provided for each area.

## Top Level Memory Map

The following table is based on the memory map (see page 1) above and uses color coding to indicate the hierarchical address spaces.

#### Table 2: Top Level Memory Map Color Coding

| Color | Token Level |
|-------|-------------|
|       | 1           |
|       | 2           |
|       | 3           |
|       | 4           |

| Address<br>Bit | 4<br>1 | 4<br>0 | 3<br>9 | 3<br>8                                            | 3<br>7 | 3<br>6 | 3<br>5 | 3<br>4   | 3<br>3                             | 3<br>2        | 3<br>1 | 3<br>0   | 2<br>9                                                                                                                                                                            | 2<br>8 | 2<br>7                  | 2<br>6                                                                                                                                  | 2<br>5 | 2<br>4    | 2<br>3 | 2<br>2                                                                                                                                                                                            |  | 0 | Description |
|----------------|--------|--------|--------|---------------------------------------------------|--------|--------|--------|----------|------------------------------------|---------------|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|---|-------------|
| Destination    |        |        |        |                                                   |        |        |        |          |                                    |               |        |          |                                                                                                                                                                                   |        |                         |                                                                                                                                         |        |           |        |                                                                                                                                                                                                   |  |   |             |
| PCle           | 1      | I<br>D | Me     | Memory Address                                    |        |        |        |          |                                    |               |        |          | Allows logic inside the<br>device to access the<br>memory space outside<br>the device via the<br>selected PCIe<br>Controller. Writes into<br>the host controller<br>memory space. |        |                         |                                                                                                                                         |        |           |        |                                                                                                                                                                                                   |  |   |             |
| DDR4           | 0      | 1      | Me     | emory Address Provid<br>memo<br>the att<br>DDR of |        |        |        |          |                                    |               |        |          | Provides access to the memory space within the attached external DDR device.                                                                                                      |        |                         |                                                                                                                                         |        |           |        |                                                                                                                                                                                                   |  |   |             |
| GDDR6          | 0      | 0      | 0      | 0                                                 | 0      | Ct     | rl IC  | )        | C<br>H<br>I<br>D<br>Memory Address |               |        |          |                                                                                                                                                                                   |        |                         | Provides access to the<br>memory space within<br>the attached external<br>GDDR devices. Some<br>GDDR devices might<br>not be populated. |        |           |        |                                                                                                                                                                                                   |  |   |             |
| NAP            | 0      | 0      | 0      | 1                                                 | 0      | 0      | 0      | N/<br>Co | IAP<br>Column                      |               |        | N/<br>Ro | AP<br>Dw Memory Address                                                                                                                                                           |        |                         |                                                                                                                                         |        |           |        | Provides access to any<br>address map attached<br>to an individual map.<br>The 28-bits of Memory<br>Address are output<br>from the<br>NAP_MASTER to the<br>fabric design attached<br>to that NAP. |  |   |             |
| CSR Space      | 0      | 0      | 1      | 0                                                 | 0      | 0      | 0      | 0        | Та                                 | rget          | : ID   |          |                                                                                                                                                                                   |        | IP ID Memory<br>Address |                                                                                                                                         |        | ery<br>SS |        | Provides access to the<br>configuration and<br>status registers. Each<br>part of the device (hard<br>IP, eNoC, PLLs etc)<br>has its own Target ID.                                                |  |   |             |
| FCU            | 0      | 0      | 1      | 1                                                 | 0      | 0      | 0      | 0        | 0                                  | 0 0 0 FCU Add |        |          |                                                                                                                                                                                   |        |                         | ddress                                                                                                                                  |        |           |        | Provides access to the FCU register space.                                                                                                                                                        |  |   |             |

## Table 3: Top Level Memory Map

## Token Hierarchy Levels

The Tcl Test Scripts API uses a Tcl dictionary whereby all locations in the memory map are identified with multilevel text tokens making it easier to find an address without requiring hand computation. The token hierarchy levels are described below.

## Level 1

The top level spaces each have their own token i.e., PCIE\_SPACE, DDR4\_SPACE, GDDR6\_SPACE, NAP\_SPACE, CSR\_SPACE. These spaces, and their associated tokens can be determined using the command get\_dict\_spaces iteratively.



The FCU does not currently have a dictionary space, as the FCU BFM is used for this simulation flow and the FCU BFM does not contain the FCU registers.

## Level 2

The available level 2 tokens vary dependent upon the top level space selected. The available tokens are shown in the console outputs below, along with the commands to find these tokens.

## Note

Every level 2 area has a "BASE" token. This returns the address at the base (offset = 0) of that address space.

```
# Print to the console the list of memory space keys in the dictionary
set top_level_spaces [get_dict_spaces]
foreach space $top_level_spaces {
    ac7t1500::get_dict_spaces $space
}
## Console output
# Level 1 tokens
Available dictionary spaces at the top level are CSR_SPACE NAP_SPACE PCIE_SPACE DDR4_SPACE
GDDR6_SPACE
# Level 2 tokens per Top level space
Available dictionary spaces for CSR_SPACE are BASE GDDR_0 GDDR_1 GDDR_2 GDDR_3 GDDR_4 GDDR_5
GDDR_6 GDDR_7 CLK_NE CLK_NW CLK_SE CLK_SW GPIO_S GPIO_N DDR4 ETHERNET_0 ETHERNET_1 ENOC_NW
ENOC_NE ENOC_S ENOC_SW ENOC_SE PCIE_0 PCIE_1
Available dictionary spaces for NAP_SPACE are BASE
Available dictionary spaces for PCIE_SPACE are BASE PCIEx8 PCIEx16
Available dictionary spaces for DDR4_SPACE are BASE
Available dictionary spaces for GDDR6_SPACE are BASE GDDR_0 GDDR_1 GDDR_2 GDDR_3 GDDR_4 GDDR_5
GDDR_6 GDDR_7
```

## Level 3

Level 3 tokens only exist for those spaces which require an additional level. Only the GDDR6 controllers and the CSR space have a level 3 token:

- The GDDR6 space has tokens CH\_0 and CH\_1 for each channel within the controller
- The CSR space has a list of IP ID tokens for the selected IP

An example is given below for the Ethernet\_0 IP subsystem. The same command can be used to get the IP ID spaces for all the level 2 tokens under the CSR\_SPACE

|      | Note                                                                                                                                                                                                                                                                                                                         |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | The names of the DBI registers for each PCIe controller can be listed using the get_dict_spaces command as shown in the example below. These registers cannot be accessed with any csr_xxxx command because they are indirect registers that are read and written via 4 DBI registers that provide the indirection. Instead: |
|      | 1. Source the pcie_utils.tcl file.                                                                                                                                                                                                                                                                                           |
|      | <ol> <li>Use the pcie_utils::dbi_read and pcie_utils::dbi_write functions to read and write<br/>these registers respectively.</li> </ol>                                                                                                                                                                                     |
|      | ac7t1500::get_dict_spaces CSR_SPACE PCIE_0 CORE_REGS                                                                                                                                                                                                                                                                         |
|      |                                                                                                                                                                                                                                                                                                                              |
| # Co | ommand to get Ethernet_0 IP ID spaces, (level 3)                                                                                                                                                                                                                                                                             |
| ac7t | t1500::get_dict_spaces CSR_SPACE ETHERNET_0                                                                                                                                                                                                                                                                                  |

# Console output

Available dictionary spaces for CSR\_SPACE ETHERNET\_0 are QUAD\_PCS\_0 QUAD\_PCS\_1 QUAD\_MAC\_0 QUAD\_MAC\_1 400G\_PCS\_0 400G\_MAC\_0 400G\_MAC\_1 CFG\_EIU

## Level 4

Level 4 tokens only apply to the CSR space, and these are the actual register names. An additional feature allows a wildcard to be used on this level to filter the potentially long list of register names returned for certain areas. An example is given below.

| # Command to get ENOC_NE registers. Note that there is only one IP ID space, so <b>this</b> defaults to BASE_IP<br>ac7t1500::get_dict_spaces CSR_SPACE ENOC_NE BASE_IP                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre># Console output<br/>The register names for CSR_SPACE ENOC_SW BASE_IP are BASE CL1_CSR_CFG0 CL1_CSR_CFG1 CL2_CSR_CFG<br/>CL3_CSR_CFG CL4_CSR_CFG RIIU_CSR_0_CFG_ACCESS_ENABLE RIIU_CSR_1_CFG_ACCESS_ENABLE<br/>RIIU_CSR_2_CFG_ACCESS_ENABLE RIIU_CSR_3_CFG_ACCESS_ENABLE CLK_RST_TOP_CSR_INOC_31_0<br/>CLK_RST_TOP_CSR_INOC_63_32 CLK_RST_TOP_CSR_INOC_95_64 UNNAMED_0x30 CLK_RST_TOP_CSR_INTERNAL_31_0<br/>CLK_RST_TOP_CSR_INTERNAL_63_32 CLK_RST_TOP_CSR_INTERNAL_95_64 UNNAMED_0x44<br/>CLK_RST_TOP_CSR_INTERNAL_CSR_STATUS CLK_RST_TOP_CSR_USER_MODE</pre> |

## Variables under the ACE Tcl Console

When running in the ACE Tcl console, there are two Tcl variables used by the script; one mandatory and one optional. Both can be set in the Tcl console window before running a script:

```
# To set a Tcl variable
set jtag_id ACP1234X
# To clear a Tcl variable
unset jtag_id
# To find out what value a variable is set to
puts $jtag_id
```

#### Table 4: Tcl Script Variables

| Variable<br>Name | Mandatory | Description                                                                                                                                                                                               |
|------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| jtag_id          | Yes       | Must be set before scripts are run. Must match the JTAG ID value of the particular programming pod. These are the same variables used directly in the JTAG Tcl Commands                                   |
| quiet_script     | No        | If set to any value other than 0, calls <pre>jtag::apb_write()</pre> and <pre>jtag::apb_read() without the -print option. This allows for scripts to run cleanly without excessive console logging.</pre> |

# Dictionary API Commands

## **Table 5: Dictionary API Commands**

| Command                     | Arguments                                                                                                  | Function                                                                                                                        | Comments                                                                                                                                                                                                                                      |
|-----------------------------|------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interrogate the Dictionarie | es                                                                                                         |                                                                                                                                 |                                                                                                                                                                                                                                               |
|                             | None                                                                                                       | Returns the top address map spaces.                                                                                             | PCIE_SPACE, DDR4_SPACE, GDDR6_SPACE, NAP_SPACE, CSR_SPACE.                                                                                                                                                                                    |
|                             | <level 1="" token=""></level>                                                                              | Returns the<br>level 2 tokens<br>under the top<br>level space.                                                                  | See list of available tokens under level 2.                                                                                                                                                                                                   |
| get_dict_spaces             | <level 1="" token=""><br/><level 2="" token=""></level></level>                                            | Returns a list<br>of level 3<br>tokens. If<br>using<br>CSR_SPACE,<br>these are the<br>CSR IP areas<br>under the<br>specific IP. | See level 3 token descriptions.                                                                                                                                                                                                               |
|                             | CSR_SPACE<br><ip name=""> <ip<br>area&gt;</ip<br></ip>                                                     | Return a list<br>of CSR<br>registers<br>under the<br>specific IP<br>and IP ID.                                                  | Returns register names. Note : Can be a long list.                                                                                                                                                                                            |
|                             | CSR_SPACE<br><ip name=""> <ip<br>area&gt; <register<br>name&gt;</register<br></ip<br></ip>                 | Get entry for<br>specified<br>register<br>name.                                                                                 | <b>Returns an entry consisting of</b> :{addr[23:0]<br>reg_size default_value}                                                                                                                                                                 |
| get_csr_reg_name            | <address><br/><value></value></address>                                                                    | Reverse<br>dictionary<br>lookup.                                                                                                | Given the address (must be 11 hex digits), returns<br>the tokens that specify that address.<br>For example, given 08091340264, returns:<br>get_csr_reg_name() success. The<br>address 08091340264 equates to<br>CSR_SPACE DDR4 PHY MICRORESET |
| Named CSR Register Acc      | esses                                                                                                      |                                                                                                                                 |                                                                                                                                                                                                                                               |
| csr_write_named             | CSR_SPACE<br><ip name=""> <ip<br>area&gt; <register<br>name&gt; <value></value></register<br></ip<br></ip> | Write to the selected register.                                                                                                 | Value is treated as hex with or without leading '0x'.                                                                                                                                                                                         |

| Command                 | Arguments                                                                                                                                    | Function                                                                        | Comments                                                                                                               |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| csr_reset_named         | CSR_SPACE<br><ip name=""> <ip<br>area&gt; <register<br>name&gt;</register<br></ip<br></ip>                                                   | Reset the<br>selected<br>register to its<br>default value.                      | Default value is stored in dictionaries.                                                                               |
| csr_read_named          | CSR_SPACE<br><ip name=""> <ip<br>area&gt; <register<br>name&gt;</register<br></ip<br></ip>                                                   | Read the selected register.                                                     | Function returns register read (under ACE).                                                                            |
| csr_verify_named        | CSR_SPACE<br><ip name=""> <ip<br>area&gt; <register<br>name&gt; <value></value></register<br></ip<br></ip>                                   | Verify the<br>selected<br>register is<br>equal to<br>value.                     | When run outside of ACE, function always returns 0. The optional argument [expected value] is used in simulation only. |
| csr_read_all_regs_named | CSR_SPACE<br><ip name=""> <ip<br>area&gt;</ip<br></ip>                                                                                       | Read all the<br>registers in an<br>IP area.                                     | Prints register name to console while reading the register.                                                            |
| csr_set_bits_named      | CSR_SPACE<br><ip name=""> <ip<br>area&gt; <register<br>name&gt;<br/><low_bit><br/><high_bit></high_bit></low_bit></register<br></ip<br></ip> | Set bits<br>[high_bit:<br>low_bit] to<br>1'b1 in the<br>selected<br>register.   | Performs a read-modify-write on the register. To set a single bit, assign high_bit = low_bit.                          |
| csr_clear_bits_named    | CSR_SPACE<br><ip name=""> <ip<br>area&gt; <register<br>name&gt;<br/><low_bit><br/><high_bit></high_bit></low_bit></register<br></ip<br></ip> | Clear bits<br>[high_bit:<br>low_bit] to<br>1'b0 in the<br>selected<br>register. | Does a read-modify-write on the register. To clear a single bit, assign high_bit = low_bit.                            |

## Based CSR Register Accesses

These functions rely on a stateful Tcl flow; the base addresses must first be set before the functions may make calls using the based address. These functions are for scripts focused on a single IP block, and save repeatedly entering the same values.

| csr_named_base  | CSR_SPACE<br><ip name=""> [IP<br/>area]</ip>      | Set the<br>arguments to<br>be the stateful<br>base address<br>values. | Supports 2 to 3 arguments. If the IP_AREA is not specified, the stateful IP ID variable is set to BASE_IP (=0). |
|-----------------|---------------------------------------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| csr_write_based | <register name=""><br/><value></value></register> | Write to the selected register.                                       | The value is treated as hex with or without leading '0x'.                                                       |
| csr_reset_based | <register name=""></register>                     | Reset the<br>selected<br>register to its<br>default value.            | Default value stored in dictionaries.                                                                           |

| Command               | Arguments                                                                  | Function                                                                                       | Comments                                                                                                                                                                                                     |
|-----------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| csr_read_based        | <register name=""></register>                                              | Read the selected register.                                                                    | Function returns register read (under ACE).                                                                                                                                                                  |
| csr_verify_based      | <register name=""><br/><value></value></register>                          | Verify the<br>selected<br>register is<br>equal to<br>value.                                    | When run outside of ACE, the function always returns 0.                                                                                                                                                      |
| Individual CSR Access |                                                                            |                                                                                                |                                                                                                                                                                                                              |
| csr_named_addr        | CSR_SPACE<br><ip name=""> <ip<br>area&gt; [register<br/>name]</ip<br></ip> | Returns base<br>address of<br>the space.                                                       | 3 to 4 arguments supported. Address returned is<br>the base address of the arguments provided. If all 4<br>arguments are provided, address is the full register<br>address.                                  |
| noc_write             | <address><br/><value></value></address>                                    | Write to any<br>location in the<br>address map.<br>(*)                                         | Address must be 42-bit hex (11 characters). Value can be up to 32-bit hex. If csr_named_addr is used to obtain the base address, this function can be used by just adding on the offsets to known registers. |
| noc_read              | <address></address>                                                        | Read from<br>any location<br>in the address<br>map. <sup>(*)</sup>                             | Address must be 42-bit hex (11 characters). If csr_named_addr is used to obtain the base address, this function can be used by just adding on the offsets to known registers.                                |
| noc_verify            | <address><br/><value></value></address>                                    | Read and<br>verify the<br>result from<br>any location<br>in the address<br>map. <sup>(*)</sup> | Address must be 42-bit hex (11 characters). If csr_named_addr is used to obtain the base address, this function can be used by just adding on the offsets to known registers.                                |
| set_bits_addressed    | <address><br/><low_bit><br/><high_bit></high_bit></low_bit></address>      | Set bits<br>[high_bit:<br>low_bit] to<br>1'b1 in the<br>selected<br>address.                   | Performs a read-modify-write on the address<br>location. To set a single bit, assign high_bit =<br>low_bit.                                                                                                  |
| clear_bits_addressed  | <address><br/><low_bit><br/><high_bit></high_bit></low_bit></address>      | Clear bits<br>[high_bit:<br>low_bit] to<br>1'b0 in the<br>selected<br>address.                 | Performs a read-modify-write on the address<br>location. To clear a single bit, assign high_bit =<br>low_bit.                                                                                                |

## NAP Access

These commands access the NAP address space (not the CSR address space).

| Command                                                                                                                                                                                                                                                         | Arguments                                                                                                    | Function                                                                                                        | Comments                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| nap_axi_write                                                                                                                                                                                                                                                   | NAP_SPACE<br><nap column=""><br/><nap row=""><br/><address><br/><value></value></address></nap></nap>        | Create an AXI<br>write from the<br>selected NAP.                                                                | Address and data are only 32-bits wide. Address is<br>the AXI write address (awaddr) which does not<br>relate to selecting the NAP, obtained with column<br>and row. Data is relocated to the appropriate byte<br>lane selected by the address, in the 256-bit output<br>from the NAP.     |  |  |  |  |  |
| nap_axi_read                                                                                                                                                                                                                                                    | NAP_SPACE<br><nap column=""><br/><nap row=""><br/><address></address></nap></nap>                            | Create an AXI<br>read at the<br>selected AXI<br>NAP.                                                            | Address and data are only 32-bits wide. Address is<br>the AXI read address (araddr) which does not<br>relate to selecting the NAP, obtained with column<br>and row. Read data is relocated to the appropriate<br>byte lane, selected by the address, in the 256-bit<br>input from the NAP. |  |  |  |  |  |
| nap_axi_verify                                                                                                                                                                                                                                                  | NAP_SPACE<br><nap column=""><br/><nap row=""><br/><address><br/><value></value></address></nap></nap>        | Create an AXI<br>read at the<br>selected NAP.<br>Compare the<br>read value<br>against the<br>expected<br>value. | Address and data are only 32-bits wide. Address is<br>the AXI read address (araddr) which does not<br>relate to selecting the NAP, obtained with column<br>and row. Read data is relocated to the appropriate<br>byte lane, selected by the address, in the 256-bit<br>input from the NAP. |  |  |  |  |  |
| <b>GDDR6 and DDR4 Memory Access</b><br>To write direct into the GDDR memory arrays. To access the GDDR CSR registers, use the CSR commands. The controllers <i>must</i> have completed initialization and training for these reads and writes to be successful. |                                                                                                              |                                                                                                                 |                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| memory_write                                                                                                                                                                                                                                                    | GDDR6_SPACE<br><controller><br/><channel><br/><address><br/><value></value></address></channel></controller> | Write to the<br>selected<br>GDDR<br>memory<br>space                                                             | Controller is one of {GDDR_0 to GDDR_7}.<br>Channel is one of {CH_0 CH_1}.<br>Address is up to a 33-bit hex field.<br>Value is up to a 32-bit hex field.                                                                                                                                   |  |  |  |  |  |
| memory_read                                                                                                                                                                                                                                                     | GDDR6_SPACE<br><controller><br/><channel><br/><address></address></channel></controller>                     | Read from<br>the selected<br>GDDR<br>memory<br>space                                                            | Controller is one of {GDDR_0 to GDDR_7}.<br>Channel is one of {CH_0 CH_1}.<br>Address is up to a 33-bit hex field.<br>Returned value is 32-bit hex.                                                                                                                                        |  |  |  |  |  |
| memory_write                                                                                                                                                                                                                                                    | DDR4_SPACE<br><address><br/><value></value></address>                                                        | Write to the<br>selected<br>DDR4<br>memory<br>space                                                             | Address is up to a 40-bit hex field<br>Value is up to a 32-bit hex field                                                                                                                                                                                                                   |  |  |  |  |  |
| memory_read                                                                                                                                                                                                                                                     | DDR4_SPACE<br><address></address>                                                                            | Read from<br>the selected<br>DDR4<br>memory<br>space                                                            | Address is up to a 40-bit hex field<br>Returned value is 32-bit hex                                                                                                                                                                                                                        |  |  |  |  |  |

| Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Arguments                                                                                      | Function                                                                                      | Comments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <b>Delay or Wait</b><br>Use this to insert a wait into your command file. When run under ACE, there is approximately 1ms minimum between commands.                                                                                                                                                                                                                                                                                                                                              |                                                                                                |                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| wait_us                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <wait value<br="">(decimal)&gt;</wait>                                                         | Add a wait of<br>uS to the<br>simulation<br>command file                                      | Requires a decimal not hex value.<br>As ACE Tcl console commands are measured in<br>milliseconds, only if the value exceeds 1000 (><br>1ms) is there an associated ACE command. The<br>wait is always added in simulation.                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| wait_ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <wait value<br="">(decimal)&gt;</wait>                                                         | Add a wait of<br>nS to the<br>simulation<br>command file                                      | Requires a decimal not a hex value. Wait is based<br>on the FCU BFM cfg_clk. By default this is 250MHz<br>(4ns). Therefore any delay is in multiples of 4ns. If<br>the cfg_clk frequency is changed, the delays scale<br>accordingly to match the new clock period. This<br>command is only truly applicable to simulation as<br>the time between JTAG commands to the FCU in<br>hardware is on the order of tens of microseconds.<br>As ACE Tcl console commands are measured in<br>milliseconds, only if the value exceeds 1000000 (><br>1ms) is there an associated ACE command. The<br>wait is always added in simulation. |  |
| Programming<br>Running under ACE only.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                |                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| program_hex_file                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <hex filename<br="">(with extension)<br/>&gt; [<optional<br>arguments&gt;]</optional<br></hex> | Programs a<br>hex file. This<br>operation<br>opens the jtag<br>port and<br>leaves it<br>open. | Optional arguments are:<br>-encrypted : Encrypted hex file<br>-do_not_enter_user_mode : Do not enter user<br>mode after programming, stay in configuration<br>mode. This holds most of the IORing IPs in reset.<br>To use Windows backslashes, enclose the<br>filename and path in {} i.e., program_hex_file<br>{C:\home\my_dir\test\my_hex.hex}                                                                                                                                                                                                                                                                               |  |
| Note<br>All commands above must be prefixed with the respective device namespace. For example,<br>program_hex_file: ac7t1500::program_hex_file or ac7t1550::program_hex_file.<br>(*) Excludes FCU registers. ACE has specific commands to access the FCU registers (see Speedster7t<br>Configuration User Guide (UG094) for details). In addition, when used in a simulation flow, these<br>commands require the ECU BEM_ECU registers are only available in simulation when using the ECU BTI. |                                                                                                |                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |

## A Caution!

If an invalid read or write is encountered while using the API as shown below, the bitstream must be reprogrammed and the command run again.

The valid bit was never received. Hardware indicates invalid read data at APB address: 0422fff0000

# **Revision History**

| Version | Date        | Description      |
|---------|-------------|------------------|
| 1.0     | 23 Aug 2021 | Initial release. |



Achronix Semiconductor Corporation

2903 Bunker Hill Lane Santa Clara, CA 95054 USA Website: www.achronix.com E-mail : info@achronix.com

Copyright © 2021 Achronix Semiconductor Corporation. All rights reserved. Achronix, Speedcore, Speedster, and ACE are trademarks of Achronix Semiconductor Corporation in the U.S. and/or other countries All other trademarks are the property of their respective owners. All specifications subject to change without notice.

## Notice of Disclaimer

The information given in this document is believed to be accurate and reliable. However, Achronix Semiconductor Corporation does not give any representations or warranties as to the completeness or accuracy of such information and shall have no liability for the use of the information contained herein. Achronix Semiconductor Corporation reserves the right to make changes to this document and the information contained herein at any time and without notice. All Achronix trademarks, registered trademarks, disclaimers and patents are listed at http://www.achronix.com/legal.