Chapter 1. System Console Commands
Introduction ................................................................. 1–1
Console Commands ...................................................... 1–3
Programmable Logic Device (PLD) Commands ..................... 1–4
Board Bring-Up Commands ........................................... 1–4
JTAG Debug Command ................................................ 1–4
Clock and Reset Signal Commands .................................. 1–5
Avalon-MM and Interface Commands ................................. 1–5
Processor Commands ................................................... 1–6
Bytestream Commands ................................................ 1–7
Design Plugin Commands .............................................. 1–7
Interactive Help ......................................................... 1–12

Chapter 2. System Console Examples
Introduction ................................................................. 2–1
LED Light Show Example .............................................. 2–1
JTAG Examples ............................................................ 2–3
   Verify JTAG Chain ................................................... 2–3
   Verify Clock ............................................................ 2–4
Checksum Example ...................................................... 2–5
Nios II Processor Example .......................................... 2–7

Additional Information
Revision History .......................................................... Info—1
How to Contact Altera .................................................. Info—1
Typographic Conventions ............................................. Info—1
## 1. System Console Commands

### Introduction

The System Console performs low-level hardware debugging of SOPC Builder systems. The System Console provides read and write access to the IP cores instantiated in your SOPC Builder system. You can use the System Console for the initial bring-up of your printed circuit board and low-level testing. The System Console is the appropriate tool for all of the following system debugging tasks:

- Verifying that the clock is toggling
- Verifying component pinouts
- Testing memories and peripheral devices
- Determining the value of the reset signal
- Perform loopback testing of Avalon® Streaming (Avalon-ST) interfaces

The System Console runs in command line mode. You can work interactively or run a Tcl script. The System Console prints responses to your commands in the terminal window. To facilitate debugging with the System Console, you can include one of the four SOPC Builder components with interfaces that the System Console can use to send commands and receive data. Table 1–1 lists these components.

### Table 1–1. SOPC Builder Components for Communication with the System Console *(Note 1)*

<table>
<thead>
<tr>
<th>Component Name</th>
<th>Debugs Components with the Following Interface Types</th>
</tr>
</thead>
<tbody>
<tr>
<td>The Nios® II processor with JTAG debug enabled</td>
<td>Components that include an Avalon® Memory-Mapped (Avalon-MM) slave interface. The JTAG debug module can also control the Nios II processor for debug functionality, including starting, stopping, and stepping the processor.</td>
</tr>
<tr>
<td>JTAG to Avalon master bridge</td>
<td>Components that include an Avalon-MM slave interface</td>
</tr>
<tr>
<td>Avalon Streaming (Avalon-ST) JTAG Interface</td>
<td>Components that include an Avalon-ST interface</td>
</tr>
<tr>
<td>JTAG UART</td>
<td>The JTAG UART is an Avalon-MM slave device that can be used in conjunction with System Console to send and receive byte streams.</td>
</tr>
</tbody>
</table>

### Note to Table 1–1:

1. The System Console can also send and receive byte streams from any SLD node whether it is instantiated in SOPC Builder component provided by Altera®, a custom component, or part of your Quartus® II project; however, this approach requires detailed knowledge of the JTAG commands.

To learn more about these components refer to the following web pages and documents:

- **The Nios II Processor** product web page
- **SPI Slave/JTAG to Avalon Master Bridge Cores** chapter in volume 5 of the *Quartus II Handbook*
- **Avalon-ST JTAG Interface Core** chapter in volume 5 of the *Quartus II Handbook*
- **sld_virtual_jtag MegaFunction User Guide**
- **JTAG UART Core** chapter in volume 5 of the *Quartus II Handbook*
Figure 1–1 illustrates the interfaces of these components that the System Console can use.

**Figure 1–1. Interfaces (Paths) the System Console Can Use to Send Commands**

Altera recommends that you also include the following components in your system:

- On-chip memory
- JTAG UART
- System ID core

In its initial configuration, the System Console provides seven different types of services. Different modules can provide the same type of service. For example, both the Nios II processor and the JTAG to Avalon Bridge master provide the master service; consequently, you can use the master commands to access both of these modules.

If your system includes a Nios II/f core with a data cache it may complicate the debugging process. If you suspect that writes to memory from the data cache at nondeterministic intervals are overwriting data written by the System Console, you can disable the cache of the Nios II/f core while debugging.
You can start the System Console from a Nios II command shell.

1. Choose All Programs > Altera > Nios II EDS <version> Command Shell
   (Windows Start menu) to run a Nios II command shell.

2. To start the System Console, type the following command:
   
   system-console

You can customize your System Console environment by adding commands to the
<quartus_install_dir>/sopc_builder/system_console_macros/system_console_rc.tcl
file. On startup, System Console automatically runs any Tcl commands in this file.

Many of the System Console commands do not work unless you are
connected to a system using a programming cable.

The following sections describe how to use each type of command.

### Console Commands

The console commands enable testing. You can use console commands to identify a
module by its path, and to open and close a connection to it. The path that identifies
a module is the first argument to most of the other System Console commands. To
exercise a module, follow these steps:

1. Identify a module by specifying the path to it, using the get_service_paths
   command.

2. Open a connection to the module using the open_service command.

3. Run Tcl and System Console commands to test the module.

4. Close a connection to a module using the close_service command.

Table 1–2 describes the syntax of the five console commands.

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>get_service_types</td>
<td></td>
<td>Returns a list of the 7 services that the System Console manages: master, bytestream, processor, sld, jtag_debug, device, and plugin.</td>
</tr>
<tr>
<td>get_service_paths</td>
<td>&lt;service_type_name&gt;</td>
<td>Returns a list of paths to nodes that implement the requested service type.</td>
</tr>
<tr>
<td>open_service</td>
<td>&lt;service_type_name&gt;, &lt;service_path&gt;</td>
<td>Opens the service type specified.</td>
</tr>
<tr>
<td>close_service</td>
<td>&lt;service_type_name&gt;, &lt;service_path&gt;</td>
<td>Closes the service type specified.</td>
</tr>
<tr>
<td>is_service_open</td>
<td>&lt;service_type_name&gt;, &lt;service_path&gt;</td>
<td>Returns 1 if the service type provided by the path is open, 0 if the service type is closed.</td>
</tr>
</tbody>
</table>
Programmable Logic Device (PLD) Commands

The PLD commands provide access to programmable logic devices on your board. Before using these commands, you must identify the path to the programmable logic device on your board using the `get_service_paths` command described in Table 1–2.

Table 1–3 describes the PLD commands.

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>device_download_sof</code></td>
<td><code>&lt;device_path&gt;</code>,</td>
<td>This command loads the specified SRAM object file (.sof) file to the</td>
</tr>
<tr>
<td></td>
<td><code>&lt;sof_file&gt;</code></td>
<td>device specified by the path.</td>
</tr>
<tr>
<td><code>device_load_jdi</code></td>
<td><code>&lt;device_path&gt;</code>,</td>
<td>This command renames the Tcl interface layer’s nodes to the names</td>
</tr>
<tr>
<td></td>
<td><code>&lt;jdi_file&gt;</code></td>
<td>specified in the JTAG debug interface (.jdi) file, making your design</td>
</tr>
<tr>
<td></td>
<td></td>
<td>easier to understand.</td>
</tr>
</tbody>
</table>

Board Bring-Up Commands

The board bring-up commands allow you to test your system. These commands are presented in the order that you would use them during board bring-up, including the following four stages:

1. Verify JTAG connectivity
2. Verify the clock and reset signals
3. Verify memory and other peripheral interfaces
4. Verify basic Nios II processor functionality

The System Console is intended for debugging the basic hardware functionality of your Nios II processor, including its memories and pinout. Once the hardware is functioning correctly, you can refer to the Nios II Software Build Tool Reference in the Nios II Software Developer’s Handbook for further software debugging. If you are writing device drivers, you may want to use the System Console and the Nios II software build tools together to debug your code.

JTAG Debug Command

You can use this command to verify the functionality and signal integrity of your JTAG chain. Your JTAG chain must be functioning correctly to debug the rest of your system. To verify signal integrity of your JTAG chain, Altera recommends that you provide an extensive list of byte values. Table 1–4 lists this command.
Clock and Reset Signal Commands

The next stage of board bring-up tests the clock and reset signals. Table 1–5 lists the three commands to verify these signals. You can use these commands to verify that your clock is toggling and that the reset signal has the expected value.

### Table 1–5. Clock and Reset Commands

<table>
<thead>
<tr>
<th>Command</th>
<th>Argument</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>jtag_debug_sample_clock</td>
<td>&lt;path&gt;</td>
<td>Returns the value of the clock signal of the system clock that drives the module’s system interface. The clock value is sampled asynchronously; consequently, you may need to sample the clock several times to guarantee that it is toggling.</td>
</tr>
<tr>
<td>jtag_debug_sample_reset</td>
<td>&lt;path&gt;</td>
<td>Returns the value of the reset signal of the system reset that drives the module’s system interface.</td>
</tr>
<tr>
<td>jtag_debug_sense_clock</td>
<td>&lt;path&gt;</td>
<td>Returns the result of a sticky bit that monitors for system clock activity. If the clock has ever toggled, the bit is 1. Returns true if the bit has ever toggled and otherwise returns false. The sticky bit is reset to 0 on read.</td>
</tr>
</tbody>
</table>

Avalon-MM and Interface Commands

These commands allow you to test the modules included in your FPGA. You can read or write the Avalon-MM interfaces using the master read and write commands. Additionally, you can use the SLD commands to shift values into the instruction and data registers of SLD nodes and read the previous value. Table 1–6 lists these commands.

### Table 1–6. Module Commands

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>master_write_memory</td>
<td>&lt;path&gt;, &lt;address&gt;,</td>
<td>Writes the specified value to the specified path and address. Values are given in hexadecimal format with the 0x prefix and delineated by spaces.</td>
</tr>
<tr>
<td>master_write_8</td>
<td>&lt;path&gt;, &lt;address&gt;,</td>
<td></td>
</tr>
<tr>
<td>master_write_16</td>
<td>&lt;path&gt;, &lt;address&gt;,</td>
<td></td>
</tr>
<tr>
<td>master_write_32</td>
<td>&lt;path&gt;, &lt;address&gt;,</td>
<td></td>
</tr>
</tbody>
</table>
Processor Commands

These commands allow you to start, stop, and step through software running on a Nios II processor. They also allow you to read and write the processor’s registers. Table 1–7 lists the commands.

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>processor_run</td>
<td>&lt;path&gt;</td>
<td>Puts the processor into run mode.</td>
</tr>
<tr>
<td>processor_stop</td>
<td>&lt;path&gt;</td>
<td>Puts the processor into stop mode.</td>
</tr>
<tr>
<td>processor_step</td>
<td>&lt;path&gt;</td>
<td>Executes one assembly instruction.</td>
</tr>
<tr>
<td>processor_get_register_names</td>
<td>&lt;path&gt;</td>
<td>Returns a list with the names of all of the processor’s accessible registers.</td>
</tr>
</tbody>
</table>

Table 1–6. Module Commands *(Note 1)*

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>master_read_memory</td>
<td>&lt;path&gt;, &lt;base_address&gt;, &lt;size_in_bytes&gt;</td>
<td>Returns a list of read values.</td>
</tr>
<tr>
<td>master_read_8</td>
<td>&lt;path&gt;, &lt;base_address&gt;, &lt;size_in_bytes&gt;</td>
<td></td>
</tr>
<tr>
<td>master_read_16</td>
<td>&lt;path&gt;, &lt;base_address&gt;, &lt;size_in_multiples_of_16_bits&gt;</td>
<td></td>
</tr>
<tr>
<td>master_read_32</td>
<td>&lt;path&gt;, &lt;base_address&gt;, &lt;size_in_multiples_of_32_bits&gt;</td>
<td></td>
</tr>
</tbody>
</table>

**SLD Commands**

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>sld_access_ir</td>
<td>&lt;path&gt;, &lt;value&gt;, &lt;timeout&gt; (in µseconds)</td>
<td>Shifts the instruction value into the instruction register of the specified node. Returns the previous value of the instruction. If the timeout value is set to 0, the operation never times out. A suggested starting value for timeout is 1000 µseconds.</td>
</tr>
<tr>
<td>sld_access_dr</td>
<td>&lt;path&gt;, &lt;size_in_bits&gt;, &lt;timeout&gt; (in µseconds), &lt;list_of_byte_values&gt;</td>
<td>Shifts the byte values into the data register of the SLD node up to the size in bits specified. If the timeout value is set to 0, the operation never times out. Returns the previous contents of the data register. A suggested starting value for timeout is 1000 µseconds.</td>
</tr>
<tr>
<td>sld_lock</td>
<td>sld_lock &lt;path&gt;, &lt;timeout&gt; (in mseconds)</td>
<td>Locks the SLD chain to guarantee exclusive access. If the SLD chain is already locked, tries for &lt;timeout&gt; mseconds before returning -1, indicating an error. Returns 0 if successful.</td>
</tr>
<tr>
<td>sld_unlock</td>
<td>sld_unlock &lt;path&gt;</td>
<td>Unlocks the SLD chain.</td>
</tr>
</tbody>
</table>

Notes to Table 1–6:

1. Transfers performed in 16- and 32-bit sizes are packed in little endian format.

System Console User Guide © November 2009 Altera Corporation
Bytestream Commands

These commands provide access to modules that produce or consume a stream of bytes. One example of a module that operates on byte streams is the JTAG UART. Bytestream service can be built on top of SLD services which transfer bits. You can use the bytestream service to communicate directly to the Altera JTAG Interface and then drive Avalon-ST components. Table 1–8 lists the commands.

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>bytestream_send</td>
<td>&lt;path&gt;, &lt;list_of_byte_values&gt;</td>
<td>Sends the list of byte values on the specified path. Values are in hexadecimal format and delineated by spaces.</td>
</tr>
<tr>
<td>bytestream_receive</td>
<td>&lt;path&gt;, &lt;number_of_bytes&gt;</td>
<td>Returns a list of received bytes.</td>
</tr>
</tbody>
</table>

Design Plugin Commands

The design plugin commands allow you to extend the functionality of the System Console. To use a plugin, you must enable it, using the following procedure:

1. Identify the available plugins using the get_service_paths command.
2. Enable a plugin by specifying the path to it, using the get_service_paths and plugin_enable commands. For example, the following commands enable the DesignsPluginProvider plugin
   a. get_service_paths plugin
   b. set design_plugin [lindex [get_service_paths plugin] 2]

   The get_service_paths command always returns a list. You must index into the list using the lindex command. In this case, the variable design_plugin is the third element on the this, (starting from 0); however, if you enable more plugins, its position on the list may change.
   c. plugin_enable $design_plugin
3. Run System Console plugin commands to test the component.
4. Disable a plugin using the plugin_disable command.
The DesignPluginProvider allows the System Console to scan your project directory for files of interest, including your Quartus II project file (.qpf) and SOPC Information File (.sopcinfo) file. Using these files, the System Console identifies Avalon-MM slave components in your design. You can use two Avalon-MM slave components, the Avalon-ST Data Pattern Checker and the Avalon-ST Data Pattern Checker, in conjunction with the System Console to test Avalon-ST interfaces in loopback mode. Figure 1–2 illustrates these components being used to perform a loopback test for a custom component with Avalon-ST interfaces.

**Figure 1–2.** Using the Data Pattern Generator and Checker To Test a Custom Component with Avalon-ST Interfaces

Table 1–9 lists the design plugin commands.

**Table 1–9.** Plugin Commands (Part 1 of 4)

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
</table>
| plugin_enable            | <plugin-path>   | Enables the plugin specified by <plugin-path> when enabled. You can retrieve the Avalon-MM slave component checkers using the get_service_types service.
| plugin_disable           | <plugin-path>   | Disables the plugin specified by <plugin-path> when disabled.
| is_plugin_enabled        | <plugin-path>   | Returns a non-zero value when the specified path is enabled. |
### Design Service Type Commands

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>design_load</code></td>
<td><code>&lt;quartus-project-path&gt;</code> or <code>&lt;qpf-file-path&gt;</code></td>
<td>Loads a model of a Quartus II design into the System Console. For example, if your <code>.qpf</code> file is in <code>c:/projects/loopback</code>, type the following command: <code>design_load /projects/loopback</code></td>
</tr>
<tr>
<td><code>design_link</code></td>
<td><code>&lt;design-path&gt;</code>, <code>&lt;device-service-path&gt;</code></td>
<td>Links a Quartus II logical design with a physical device. For example, you can link a Quartus II design called <code>2c35_quartus_design</code> to a 2c35 device. After you create this link, the System Console creates the appropriate correspondences between the logical and physical submodules of the Quartus II project. Example 1–1 on page 1–12 shows a transcript illustrating the <code>design_load</code> and <code>design_link</code> commands. Note that the System Console does not verify that the link is valid, so that if you create an incorrect link, the System Console does not report an error.</td>
</tr>
</tbody>
</table>

### Data Pattern Generator Service Type Commands

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>data_pattern_generator_start</code></td>
<td><code>&lt;service-path&gt;</code></td>
<td>Starts the data pattern generator.</td>
</tr>
<tr>
<td><code>data_pattern_generator_stop</code></td>
<td><code>&lt;service-path&gt;</code></td>
<td>Stops the data pattern generator.</td>
</tr>
<tr>
<td><code>data_pattern_generator_is_generating</code></td>
<td><code>&lt;service-path&gt;</code></td>
<td>Returns non-zero if the generator is running.</td>
</tr>
<tr>
<td><code>data_pattern_generator_inject_error</code></td>
<td><code>&lt;service-path&gt;</code></td>
<td>Injects a 1-bit error into the generator’s output.</td>
</tr>
</tbody>
</table>
### Table 1–9. Plugin Commands (Part 3 of 4)

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
</table>
| data_pattern_generator_set_pattern           | <service-path>, <pattern-name>                | Sets the output pattern set pattern specified by the <pattern-name>. In all, 6 patterns are available, 4 are pseudo-random binary sequence s (PRBS) and 2 are high and low frequency. The following pattern names are defined:  
  - PRBS7  
  - PRBS15  
  - PRBS23  
  - PRBS31  
  - HF—outputs a high frequency, constant pattern of alternating 0s and 1s  
  - LF—outputs a low frequency, constant pattern of 10b'1111100000 for 10-bit symbols and 8b'11110000 for 8-bit symbols |
| data_pattern_generator_get_pattern           | <service-path>                                | Returns currently selected output pattern.                               |
| data_pattern_generator_get_available_patterns| <service-path>                                | Returns a list of available data patterns by name.                      |
| data_pattern_generator_enable_preamble       | <service-path>                                | Enables the preamble mode at the beginning of generation.               |
| data_pattern_generator_disable_preamble      | <service-path>                                | Disables the preamble mode at the beginning of generation.              |
| data_pattern_generator_is_preamble_enabled   | <service-path>                                | Returns a non-zero value if preamble mode is enabled.                   |
| data_pattern_generator_set_preamble_word     | <service-path>, <preamble-word>               | Sets the preamble word.                                                 |
| data_pattern_generator_get_preamble_word     | <service-path>                                | Gets the preamble word.                                                 |
| data_pattern_generator_set_preamble_beats    | <service-path>, <number-of-preamble-beats>    | Sets the number of beats to send out the in the preamble word.           |
| data_pattern_generator_get_preamble_beats    | <service-path>                                | Returns the currently set number of beats to send out the preamble word.|

**Data Pattern Checker Commands**

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>data_pattern_checker_start</td>
<td>&lt;service-path&gt;</td>
<td>Starts the checker.</td>
</tr>
<tr>
<td>data_pattern_checker_stop</td>
<td>&lt;service-path&gt;</td>
<td>Stops the checker.</td>
</tr>
</tbody>
</table>
### Table 1-9. Plugin Commands (Part 4 of 4)

<table>
<thead>
<tr>
<th>Command</th>
<th>Arguments</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>data_pattern_checker_is_checking</code></td>
<td><code>&lt;service-path&gt;</code></td>
<td>Returns a non-zero value if the checker is running.</td>
</tr>
<tr>
<td><code>data_pattern_checker_is_locked</code></td>
<td><code>&lt;service-path&gt;</code></td>
<td>Returns non-zero if the checker is locked onto the incoming data.</td>
</tr>
<tr>
<td><code>data_pattern_checker_set_pattern</code></td>
<td><code>&lt;service-path&gt;</code>,</td>
<td>Sets the expected pattern to the one specified by the <code>&lt;pattern-name&gt;</code>.</td>
</tr>
<tr>
<td></td>
<td><code>&lt;pattern-name&gt;</code></td>
<td></td>
</tr>
<tr>
<td><code>data_pattern_checker_get_pattern</code></td>
<td><code>&lt;service-path&gt;</code></td>
<td>Returns the currently selected expected pattern by name.</td>
</tr>
<tr>
<td><code>data_pattern_checker_get_available_patterns</code></td>
<td><code>&lt;service-path&gt;</code></td>
<td>Returns a list of available data patterns by name.</td>
</tr>
<tr>
<td><code>data_pattern_checker_get_data</code></td>
<td><code>&lt;service-path&gt;</code></td>
<td>Returns a list of the current checker data, providing the number of bits and the number of errors.</td>
</tr>
<tr>
<td><code>data_pattern_checker_reset_counters</code></td>
<td><code>&lt;service-path&gt;</code></td>
<td>Resets the bits and error counters inside the checker.</td>
</tr>
</tbody>
</table>
Interactive Help

Typing `help help` into the System Console lists all available commands. Typing `help <command name>` provides the syntax of individual commands. The System Console provides command completion if you type the beginning letters of a command and then press the Tab key.

The System Console interactive help commands only provide help for enabled services; consequently, typing `help help` does not display help for a plugin unless you have enabled it.
2. System Console Examples

Introduction

This chapter uses three different SOPC Builder systems to demonstrate the functionality of the System Console. The System-Console.zip file contains design files for the first two example systems. This zip file includes files for both the Nios II Development Kit Cyclone® II Edition and the Nios II Development Kit Stratix® II Edition. You can download the design files for the example designs from the Altera website. A hyperlink to the design files appears next to this document on the User Guide web page.

The first example Tcl script creates a LED light show on your board. The SOPC Builder system for this example includes two modules: a JTAG to Avalon master bridge and a PIO core. The JTAG to Avalon master bridge provides a connection between your development board and SOPC Builder system via serial peripheral interface (SPI). The PIO module provides a memory-mapped interface between an Avalon-MM slave port and general-purpose IO ports.

For more information about these components refer to the SPI Slave/JTAG to Avalon Master Bridge Cores chapter in volume 5 of the Quartus II Handbook and the PIO Core chapter in volume 5 of the Quartus II Handbook.

The first example program sends a series of master_write_8 commands to the JTAG Avalon master bridge. The JTAG Avalon master sends these commands to the Avalon-MM slave port of the PIO module. The PIO I/O ports connect to FPGA pins that are, in turn, connected to the LEDs on your development board. The write commands to the PIO Avalon-MM slave port result in the light show.

The instructions for these examples assume some familiarity with the Quartus II and SOPC Builder software.

LED Light Show Example

Figure 2–1 illustrates the SOPC Builder system for the first example.
To build this example system, complete the following steps:

1. On your host computer file system, locate the following directory: `<Nios II EDS install path>\examples<verilog or vhdl>\<board version>\standard`. Each development board has a VHDL and Verilog HDL version of the design. You can use either of these design examples.

2. Copy the `standard` directory to a new location. By copying the design files, you avoid corrupting the original design and avoid issues with file permissions. This document refers to the newly-created directory as the c:\`<projects>`\standard directory.

3. Copy the `System_Console.zip` file to the c:\`<projects>`\standard directory and unzip it. The `jtag_pio_cii` and `jtag_pio_sii` directories are created for the Cyclone II and Stratix II development boards.

4. Choose All Programs > Altera > Nios II EDS <version> Command Shell (Windows Start menu) to run a Nios II command shell.

5. Change to the directory for your board.

6. To program your board with the .sof file. Type the following command in the Nios II command shell:

   ```
   nios2-configure-sof <sof_name>.sof
   ```

   If your development board includes more than one JTAG cable you must specify which cable you are communicating with as an argument to the `nios2-configure-sof <sof_name>.sof` command. To do so, type the following commands:

   a. `jtagconfig`
Figure 2–2 gives sample output from the `jtagconfig` command. This output shows that the active JTAG cable is number 2. Substitute the number of your JTAG for the `<cable_number>` variable in the following command:

```bash
b. nios2-configure-sof -c <cable_number> <sof_name>.sof
```

7. You can then run the LED light show example by typing the following command:

```bash
system-console --script=led_lightshow.tcl
```

8. You can see the LEDs performing a running light demonstration. Press Ctrl+C to stop the LED light show.

9. To see the commands that this script runs, open the `led_lightshow.tcl` file in your `jtag_pio_<cii_or_sii>` directory.

**JTAG Examples**

There are two JTAG examples. The first JTAG example gives you some practice working with the System Console as an interactive tool. The second verifies that the clock is toggling.

**Verify JTAG Chain**

In this example, you verify the JTAG chain on your board. To run this example, complete the following steps:

1. Choose All Programs > Altera > Quartus II <version> (Windows Start menu) to run the Quartus II software. Open the Quartus II project file, `jtag_pio.qpf` or `jtag_pio_sii.qpf`.

2. On the Tools menu, click SOPC Builder.

3. On the SOPC Builder Tools menu, click System Console.

4. Set the path to the `jtag_debug` service by typing the following command:

   ```bash
   set jd_path [lindex [get_service_paths jtag_debug] 0]
   ```

   The `get_service_paths` command always returns a list, even if the list has a single item; consequently, you must index into the list using the `lindex` command. In this case, the variable `jd_path` is assigned the string that is the 0th element of the list.

5. Open the `jtag_debug` service by typing the following command:

   ```bash
   open_service jtag_debug $jd_path
   ```

6. Set up a list of byte values to test the chain by typing the following command:

   ```bash
   set values [list 0xaa 0x55 0xaa 0x55 0xaa 0x55 0xaa 0x55 0xaa 0x55 0xaa 0x55 0xaa 0x55 0xaa 0x55]
   ```
7. Loop the values by typing the following command:

```
jtag_debug_loop $jd_path $values
```

If the `jtag_debug_loop` command is successful, you should see the values that you sent reflected in the System Console. Figure 2–3 shows the transcript from this interactive session.

**Figure 2–3. The jtag_debug_loop Command**

```
% set jd_path /home [get_service_paths jtag_debug] 0
/root/CONNECTIONS/USB-Blaster [USB-0]/EPPC333/[ID:110 ID:112 EHCI:0 VER:1]
% open_service jtag_debug $jd_path

% set values [list 0x55 0x55 0x55 0x55 0x55 0x55 0x55 0x55 0x55 0x55 0x55 0x55 0x55 0x55 0x55]
% jtag_debug_loop $jd_path $values
```

8. Close the `jtag_debug` service by typing the following command:

```
close_service jtag_debug $jd_path
```

This example provides the beginnings of a JTAG chain validation workflow. Depending on the number of devices and FPGAs in your JTAG chain, you can expand upon this test by performing more operations in parallel, with larger data sets, and potentially multiple devices.

**Verify Clock**

The command to verify that your clock is toggling samples the clock asynchronously. Consequently, you may need to use this command several times to determine if the clock is toggling. The `jtag_debug_sample_clock.tcl` script samples the clock 10 times. To run this script, type `source jtag_debug_sample_clock.tcl` at the System Console prompt. You should see 10 values for the JTAG clock printed to the System Console as Figure 2–4 illustrates.

**Figure 2–4. The jtag_debug_sample_clock Command**

```
% source jtag_debug_sample_clock.tcl
Service Open Status is: 1

Multiple samples of clock status

0
6
6
1
1
1
6
```

Closing `jtag_debug` service path (tcl)
Checksum Example

In this example, you add an on-chip memory and hardware accelerator to the previous SOPC Builder system. The hardware accelerator calculates a checksum. Figure 2–5 illustrates this system.

Figure 2–5. SOPC Builder System for Checksum Accelerator Example

To build this example system, complete the following steps:
1. In the System Contents tab in SOPC Builder, double-click On-Chip Memory (RAM or ROM) in the On-Chip subfolder of the Memories and Memory Controllers folder to add this component to your system.

2. In the On-Chip Memory (RAM or ROM) wizard, for Total memory size type 128 to change the memory size to 128 bytes. Click Finish to accept the other default values.

3. To connect the on-chip memory to the master, click the open dot at the intersection of the onchip_mem s1 Avalon slave port and the JTAG to Avalon Master Bridge master port.

4. In the System Contents tab, double-click Checksum Accelerator in the Custom Component folder to add this component to your system.

5. To connect the checksum accelerator Slave port, click on the open dot at the intersection of the accelerator Slave and the master master port.

6. To connect the checksum accelerator Master port, click on the open dot at the intersection of the accelerator Master and the onchip_mem s1 port.

7. In the Base column, enter the base addresses in for the slaves in your system.
   - Onchip_mem s1 port—0x00000080
   - Accelerator Slave port—0x00000020

Click on the lock icon next to each address to lock these values. Figure 2–6 illustrates the completed system.
Figure 2–6. Checksum Accelerator Module Connections

<table>
<thead>
<tr>
<th>Use</th>
<th>Conn.</th>
<th>Module Name</th>
<th>Description</th>
<th>Clock</th>
<th>Base</th>
<th>End</th>
<th>RO</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>master</td>
<td>master</td>
<td>JTAG to Avalon Master Bridge</td>
<td>clk</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Avalon Memory Mapped Master</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>jtag_pio</td>
<td>jtag_pio</td>
<td>JTAG (Parallel I/O)</td>
<td>clk</td>
<td>0x00000000</td>
<td>0x00000010</td>
<td></td>
</tr>
<tr>
<td></td>
<td>onchip_mem</td>
<td>onchip_mem</td>
<td>On-Chip Memory (RAM or ROM)</td>
<td>clk</td>
<td>0x00000000</td>
<td>0x00000010</td>
<td></td>
</tr>
<tr>
<td></td>
<td>accelerator</td>
<td>accelerator</td>
<td>Checksum Accelerator</td>
<td>clk</td>
<td>0x00000000</td>
<td>0x00000010</td>
<td></td>
</tr>
<tr>
<td></td>
<td>slaves</td>
<td>slaves</td>
<td>Avalon Memory Mapped Slave</td>
<td>clk</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>master</td>
<td>master</td>
<td>Avalon Memory Mapped Master</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

8. Save your system.

9. In the System Contents tab, click Next.

10. In the System Generation tab, click Generate.

11. On the Quartus II Processing menu, click Start Compilation.

12. When compilation completes, re-program your board by typing the following command in the Nios II command shell:
   
   nios2-configure-sof jtag_pio.sof

13. Type system-console in the Nios II command shell to start the System Console.

   If you reprogram your board, you must start a new System Console to receive the changes.sour

14. To run the checksum example, in the System Console, type:
   
   source set_memory_and_run_checksum.tcl

   Figure 2–7 shows the output from a successful run.
15. You can change the value written into the RAM by changing the value given in the `fill_memory` routine in the `set_memory_and_run_checksum.tcl` file. Save the Tcl file after editing and rerun the command. (Because the system command uses `master_write_32`, if you use values that are less than 32 bits, they are filled with leading 0s.)

**Nios II Processor Example**

In this example you program the Nios II processor on your board to run the count binary software example that is included in the Nios II installation. This is a simple program that, using an 8-bit variable, repeatedly counts from 0 to 0xFF. The output of this variable is displayed on the LEDs and the seven-segment display on your board. After programming the Nios II processor from the System Console, you use the System Console processor commands to start and stop the processor.

To run this example, complete the following steps:

1. Copy the `standard` directory for your development board to a new location. (Altera recommends that you use a separate directory structure for each project.) This project uses `C:\Count_binary\standard\`

2. Open the Quartus II project file for your board, `<board_version>_standard.qpf`. 

---

**Figure 2–7. System Console Output**

```
# System Console

# source set_memory_and_run_checksum.tcl

****************************************************************************
Setup RAM values not affect filling with data.
****************************************************************************

Starting Checksum operation.
Writing to address and length registers.
Address register value = 0x00000000
Length register value = 0x00000000

Writing clear to status register.
Writing clear to control register.

Writing 00 to control register.
Checksum DAME bit set.
Result register value (non-inverted) = 0x0F45

Writing clear to status register.
Writing clear to control register.

Writing 00 and INVERT to control register.
Checksum DAME bit set.
Result register value (inverted) = 0x0FA9

Checksum example finished.
```
3. On the Tools menu, click **SOPC Builder**.

4. In a Nios II command shell, change to the directory of your new project.

5. To program your board, type the following command in a Nios II command shell:
   ```
   nios2-configure-sof <board_version>_standard.sof
   ```

6. In your Nios II command shell, type the following:
   ```
   cd software_examples/app/count_binary
   ```

7. To build the executable and linkable format (ELF) file (.elf) for this application, type the following:
   ```
   $ ./create-this-app
   ```

   For more information about creating Nios II applications, refer to the Using the Nios II Software Build Tools chapter in the Nios II Software Developer’s Handbook.

8. Download the .elf file to your board by typing the following:
   ```
   $ nios2-download -g count_binary.elf
   ```

   The seven-segment display and LEDs on your board provides a new light show.

9. Start the System Console by typing `system-console` in your Nios II command shell.

10. Set the processor service path to the Nios II processor by typing the following command:
    ```
    set niosii_proc [lindex [get_service_paths processor] 0]
    ```

11. Set the master service path to the Nios II processor by typing the following command:
    ```
    set niosii_master [lindex [get_service_paths master] 0]
    ```

12. Open both services by typing the following commands:
    ```
    open_service processor $niosii_proc
    open_service master $niosii_master
    ```

13. Stop the processor by typing the following command:
    ```
    processor_stop $niosii_proc
    ```

    The LEDs and seven-segment display on your board freezes.

14. Start the processor by typing the following command:
    ```
    processor_run $niosii_proc
    ```

    The LEDs and seven-segment display on your board resume their previous activity.

15. Stop the processor by typing the following command:
    ```
    processor_stop $niosii_proc
    ```

16. Close the services by typing the following command:
    ```
    close_service master $niosii_master
    close_service processor $niosii_proc
    ```

    The `processor_step`, `processor_set_register` and `processor_get_register` provide additional control over the Nios II processor.
Revision History

The table below displays the revision history for the chapters in this User Guide.

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Changes Made</th>
</tr>
</thead>
<tbody>
<tr>
<td>November 2009</td>
<td>1.3</td>
<td>■ Added the design plugin commands.</td>
</tr>
<tr>
<td>March 2009</td>
<td>1.2</td>
<td>■ Added sld_lock and sld_unlock commands</td>
</tr>
<tr>
<td>November 2008</td>
<td>1.1</td>
<td>■ Added device service type commands.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>■ Expanded section explaining the system requirements for accessing the System Console.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>■ Added Figure 1–1 showing System Console connectivity.</td>
</tr>
<tr>
<td>May 2008</td>
<td>1.0</td>
<td>Initial Release.</td>
</tr>
</tbody>
</table>

How to Contact Altera

For the most up-to-date information about Altera® products, see the following table.

<table>
<thead>
<tr>
<th>Contact</th>
<th>Contact Method</th>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>Technical support</td>
<td>Website</td>
<td><a href="http://www.altera.com/support">www.altera.com/support</a></td>
</tr>
<tr>
<td>Technical training</td>
<td>Website</td>
<td><a href="http://www.altera.com/training">www.altera.com/training</a></td>
</tr>
<tr>
<td></td>
<td>Email</td>
<td><a href="mailto:custrain@altera.com">custrain@altera.com</a></td>
</tr>
<tr>
<td>Altera literature services</td>
<td>Email</td>
<td><a href="mailto:literature@altera.com">literature@altera.com</a></td>
</tr>
<tr>
<td>Non-technical support</td>
<td>Email</td>
<td><a href="mailto:nacomp@altera.com">nacomp@altera.com</a></td>
</tr>
<tr>
<td>(General)</td>
<td>Email</td>
<td><a href="mailto:authorization@altera.com">authorization@altera.com</a></td>
</tr>
<tr>
<td>(Software Licensing)</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Note:
(1) You can also contact your local Altera sales office or sales representative.

Typographic Conventions

The following table shows the typographic conventions that this document uses.

<table>
<thead>
<tr>
<th>Visual Cue</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Bold Type with Initial Capital Letters</strong></td>
<td>Indicates command names, dialog box titles, dialog box options, and other GUI labels. For example, Save As dialog box.</td>
</tr>
<tr>
<td><strong>bold type</strong></td>
<td>Indicates directory names, project names, disk drive names, file names, file name extensions, and software utility names. For example, \qdesigns directory, d: drive, and chiptrip.gdf file.</td>
</tr>
<tr>
<td><em>Italic Type with Initial Capital Letters</em></td>
<td>Indicates document titles. For example, AN 519: Stratix IV Design Guidelines.</td>
</tr>
<tr>
<td><strong>Italic type</strong></td>
<td>Indicates variables. For example, ( n + 1 ). Variable names are enclosed in angle brackets (&lt;&gt;). For example, &lt;file name&gt; and &lt;project name&gt;.pof file.</td>
</tr>
<tr>
<td>Visual Cue</td>
<td>Meaning</td>
</tr>
<tr>
<td>---------------------</td>
<td>-----------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>Initial Capital Letters</td>
<td>Indicates keyboard keys and menu names. For example, Delete key and the Options menu.</td>
</tr>
<tr>
<td>“Subheading Title”</td>
<td>Quotation marks indicate references to sections within a document and titles of Quartus II Help topics. For example, “Typographic Conventions.”</td>
</tr>
<tr>
<td>Courier type</td>
<td>Indicates signal, port, register, bit, block, and primitive names. For example, data1, tdi, and input. Active-low signals are denoted by suffix n. For example, resetn.</td>
</tr>
<tr>
<td></td>
<td>Indicates command line commands and anything that must be typed exactly as it appears. For example, c:\qdesigns\tutorial\chiptrip.gdf.</td>
</tr>
<tr>
<td></td>
<td>Also indicates sections of an actual file, such as a Report File, references to parts of files (for example, the AHDL keyword SUBDESIGN), and logic function names (for example, TRI).</td>
</tr>
<tr>
<td>1., 2., 3., and a., b., c., and so on.</td>
<td>Numbered steps indicate a list of items when the sequence of the items is important, such as the steps listed in a procedure.</td>
</tr>
<tr>
<td>■ ■</td>
<td>Bullets indicate a list of items when the sequence of the items is not important.</td>
</tr>
<tr>
<td>■</td>
<td>The hand points to information that requires special attention.</td>
</tr>
<tr>
<td></td>
<td>A caution calls attention to a condition or possible situation that can damage or destroy the product or your work.</td>
</tr>
<tr>
<td></td>
<td>A warning calls attention to a condition or possible situation that can cause you injury.</td>
</tr>
<tr>
<td></td>
<td>The angled arrow instructs you to press Enter.</td>
</tr>
<tr>
<td></td>
<td>The feet direct you to more information about a particular topic.</td>
</tr>
</tbody>
</table>