# AXEL-X MB8AA3020 On-Chip Code User Manual

**REVISION 1.2** 

# **TABLE OF CONTENTS**

| TABLE OF CONTENTS                                                          |   |
|----------------------------------------------------------------------------|---|
| LIST OF FIGURES                                                            | 3 |
| LIST OF TABLES                                                             |   |
| 1.0 ABOUT THIS MANUAL                                                      | 4 |
| 1.1 DOCUMENT OVERVIEW         1.2 ACRONYMS                                 |   |
| 2.0 INTRODUCTION                                                           | 6 |
| <ul> <li>2.1 BYTE .DATA ORGANIZATION</li> <li>2.2 MICRO-COMMANDS</li></ul> |   |
| 3.0 MICRO-ENGINE DESCRIPTION                                               |   |
| <ul> <li>3.1 TASK STRUCTURE</li></ul>                                      |   |
| 4.0 BUILDING MB8AA3020 FIRMWARE IMAGE                                      |   |
| 4.1 Build Procedure                                                        |   |

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

# LIST OF FIGURES

| Figure 1 | Field Description MAC Address and EtherType Field | 9  |
|----------|---------------------------------------------------|----|
| 0        | Initialization Sequence                           |    |
| Figure 3 | Initialization Sequence for MII/GMII Task         | 23 |
| Figure 4 | Initialization Sequence for 10GBE Task            | 24 |

# LIST OF TABLES

| Table 1 Data Byte Relationship | 7  |
|--------------------------------|----|
| Table 2 Micro-Commands         |    |
| Table 3 Task Description       | 20 |

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

## **1.0 About This Manual**

This document is intended to provide configuration description for Fujitsu MB8AA3020 10Gbps Ethernet switch on chip code.

#### **1.1 Document Overview**

The document includes a description of the following:

- Getting started example
- Micro-engine specification
- Memory map description
- Initialization sequence
- Global variable description
- Task descriptions
- Initialization code block

While all registers can be modified using the On-Chip code these are the main registers that are supplied by default:

- All setting in the switch configuration registers.
- All setting in the port configuration registers.
- All port interrupt status registers.
- Switch status register.
- Buffer management register.
- Management port control register.
- Host VLAN counter configuration register.
- MAC configuration register.
- MII/GMII status control register.
- Default MAC addresses for the switch and all ports.
- Fixed or adaptive gain for receiver equalizer.

The above list while not exhaustive illustrates the programmability of the MB8AA3020.

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

#### 1.2 Acronyms

| EEPROM<br>ENV | Electrically Erasable Read Only Memory<br>Environment |
|---------------|-------------------------------------------------------|
| GMII          | Giga-bit Media Independent Interface                  |
| ICB           | Initialization Code Block                             |
| I/F           | Interface                                             |
| IRQ           | Interrupt Request                                     |
| LAN           | Local Area Network                                    |
| MAT           | MAC Address Table                                     |
| MII           | Media Independent Interface                           |
| MAC           | Medium Access Control                                 |
| RAM           | Random Access Memory                                  |
| VLAN          | Virtual Local Area Network                            |

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

# 2.0 Introduction

This section focuses on a step by step example of how to configure and compile the MB8AA3020 AXEL-X on chip code. It uses the MB8AA3020 AXEL-X evaluation board as an example, for a more detail description of the MB8AA3020 AXEL-X evaluation board please refer to *AXEL-X Evaluation Board Hardware Manual.* 

The generic firmware that is included with the Fujitsu MB8AA3020 AXEL-X chip does not assign MAC addresses to the ports or the chip so at the very least the user must assign a MAC address for every port as well as the chip address for the 10GBE switch to function properly.

In addition to this the user must decide whether to use fixed or dynamic gain before compiling the firmware.

Before we begin our example we must first understand how the byte structure is organized in the assembly files as well as understand the various microcommands. Section 2.1 Byte .data Organization describes the byte structure organization while Section 2.2 Micro-commands describes the micro-commands.

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

#### 2.1 Byte .data Organization

In order to begin configuring the on chip code firmware we must first understand how the byte structure is set up in the assembly files.

Below is an example of a factious symbol and the .*data* fields associated with the symbol.

The organization of the .*data* fields always start with byte 1 and byte 0 corresponding to the first data field, byte 3 and byte 2 corresponding to the second data field and so on. Table 1 Data Byte Relationship describes the Data Byte relationship.

| Data  | Bytes          |
|-------|----------------|
| .data | Byte 1 Byte 0  |
| .data | Byte 3, Byte 2 |
| .data | Byte 5, Byte 4 |
| .data | Byte 7, Byte 6 |

**Table 1 Data Byte Relationship** 

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

#### 2.2 Micro-commands

Listed in Table 2 is a list of commonly used micro-commands that are executed by the MB8AA3020 micro-engine.

| Micro-command | Description                                | Example                               |
|---------------|--------------------------------------------|---------------------------------------|
| .align_block  | Align the block frame                      | N/A                                   |
| .skip         | Skip the current instruction               | .data 0x1234<br>.skip<br>.data 0x4567 |
| .data         | Assigns a 16 bit value to the data         | .data <16 bit value>                  |
| .data_ref     | The data is reference to a pointer that is | .data_ref ICB_PCS_0                   |
|               | defined by the user                        | ICB_PCS_0:                            |
|               | using " <b>:</b> "                         | .data 0x1234                          |
|               |                                            | .data 0x4567                          |
|               |                                            | .skip                                 |
|               |                                            | .skip                                 |

Table 2 Micro-Commands

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

#### 2.3 Getting Started

F

As mentioned in the introduction at the very least the user must set up the MAC address for every port as well as the chip for the 10GBE switch to function properly.

#### 2.3.1 Assigning MAC Addresses

By default the source code provided by the Fujitsu MB8AA3020 has a MAC address and EtherType of 0. So at the very minimum the user must assign a valid MAC address and Ethertype to every port and the station address in order for the switch to function properly. These variables can be found in the MAC\_address.asm file under the symbol Hst\_Adr\_[0-23]. Shown in Figure 1 is the field description for the MAC address and EtherType field.

|            | Byte 7                         | Byte 6 | Byte 5        | Byte 4              | Byte 3        | Byte 2  | Byte 1  | Byte 0  | description |
|------------|--------------------------------|--------|---------------|---------------------|---------------|---------|---------|---------|-------------|
|            |                                |        |               |                     |               |         |         |         |             |
|            |                                | MAG    | A d dro o o . | x:xx:xx:xx          |               |         | N       | /A      | Port 0      |
| Hst_Adr_0  |                                |        |               |                     |               |         |         |         |             |
| Hst_Adr_1  |                                |        |               | x:xx:xx:xx          |               |         | N       | /A      | Port 1      |
| Hst_Adr_2  |                                | MAC    | Address >     | x:xx:xx:xx          | :xx:xx        |         | N       | /A      | Port 2      |
| Hst_Adr_3  |                                | MAC    | Address >     | x:xx:xx:xx          | XX:XX         |         | N/A     |         | Port 3      |
| Hst_Adr_4  |                                | MAC    | Address >     | x:xx:xx:xx          | :xx:xx        |         | N       | /A      | Port 4      |
| Hst_Adr_5  |                                | MAC    | Address >     | x:xx:xx:xx          | :xx:xx        |         | N/A     |         | Port 5      |
| Hst_Adr_6  |                                | MAC    | Address >     | x:xx:xx:xx          | :xx:xx        |         | N       | /A      | Port 6      |
| Hst_Adr_7  |                                | MAC    | Address >     | x:xx:xx:xx          | :xx:xx:xx:xx  |         | N/A     |         | Port 7      |
| Hst_Adr_8  | MAC Address xx:xx:xx:xx:xx:xx  |        |               |                     | N/A           |         | Port 8  |         |             |
| Hst_Adr_9  | MAC Address xx:xx:xx:xx:xx:xx  |        |               | N/A                 |               | Port 9  |         |         |             |
| Hst_Adr_10 | MAC Address xx:xx:xx:xx:xx:xx  |        | :xx:xx        |                     | N/A           |         | Port 10 |         |             |
| Hst_Adr_11 | MAC Address                    |        | Address >     | xx:xx:xx:xx:xx:xx   |               | N/A     |         | Port 11 |             |
| Hst_Adr_12 | MAC Address                    |        | Address >     | s xx:xx:xx:xx:xx:xx |               | N/A     |         | Port 12 |             |
| Hst_Adr_13 | MAC Address                    |        | Address >     | s xx:xx:xx:xx:xx:xx |               |         | N/A     |         | Port 13     |
| Hst_Adr_14 |                                | MAC    | Address >     | x:xx:xx:xx          | :xx:xx        |         | N       | /A      | Port 14     |
| Hst_Adr_15 |                                | MAC    | Address >     | x:xx:xx:xx          | :xx:xx        |         | N       | /A      | Port 15     |
| Hst_Adr_16 |                                | MAC    | Address >     | x:xx:xx:xx          | :xx:xx        |         | N       | /A      | Port 16     |
| Hst_Adr_17 | MAC Address xx:xx:xx:xx:xx:xx  |        |               | N/A                 |               | Port 17 |         |         |             |
| Hst_Adr_18 | MAC Address xx:xx:xx:xx:xx:xx  |        |               | N                   | /A            | Port 19 |         |         |             |
| Hst_Adr_19 |                                | MAC    | Address >     | x:xx:xx:xx          | x:xx:xx:xx:xx |         | N/A     |         | Port 20     |
| Hst_Adr_21 |                                | MAC    | Address >     | xx:xx:xx:xx:xx:xx   |               |         | N/A     |         | Port 21     |
| Hst_Adr_23 | MAC Address xx:xx:xx:xx:xx N/A |        |               |                     |               | /A      | Port 23 |         |             |
| nst_Aut_25 |                                | MAC    | Addiess A     |                     |               |         |         | / .     | 1 011 23    |

| Reg_STA |                               |           |
|---------|-------------------------------|-----------|
|         | MAC Address xx:xx:xx:xx:xx:xx | Ethertype |
|         |                               |           |
|         | Register Station              |           |

Figure 1 Field Description MAC Address and EtherType Field

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

# Note: It is important to note that in order for the switch to function properly a valid MAC address must be assigned for every port and station address.

Below is an excerpt from the MAC\_address.asm file. The first data field is two bytes long and refer to the EtherType, the rest of the *.data* field refer to the MAC address. The EtherType is only used in the REG\_STA address there is no requirement to assign an EtherType for the ports.

#### Example: MAC Address Assignment to REG\_STA

Below is an example where a MAC address of 00-11-F5-76-82-61 and an EtherType of 88B5 to the *REG\_STA*.

```
// MAC Addresses: API Access
//
Reg_STA: // 00:11:F5:76:82:61
   .data   0x88b5   // type = 0x88b5
   .data    0x8261   // msw = 82_61
   .data    0xF576   // lsw2 = F5_76
   .data    0x0011   // lsw1 = 00_11
```

#### Example: MAC Address Assignment to PORT 0

permission from FUJITSU Ltd.

Below is an example where a MAC address of 00-11-F5-AB-CD-EF is applied to port 0. Recall that for ports an EtherType entry is not required.

#### 2.3.2 Configuring 10GBE Transmitter and Receiver

Fujitsu MB8AA3020 10GBE switch has an integrated 5-TAP FIR filter used for additional pre-emphasis and a 2<sup>nd</sup> order linear amplifier used for receiver equalization. The details of which can be found in *AXEL-X MB8AA3020 PCS Register Specification.* 

Before programming the on-chip the user must decide on the following configuration parameters:

- XAUI mode of operation of XFI mode of operation for XFI 10GBE ports.
- Transmit pre-emphasis co-efficient to be used.
- Fixed gain or adaptive gain equalization for the receiver
- Transmitter lane swapping.
- Transmitter polarity swapping.
- Receiver lane swapping.
- Receiver polarity swapping.

Below is an example of how to modify the on-chip code for adaptive gain.

#### Example: Modification of Receiver Gain.

In order to modify the receiver for fixed or dynamic gain open the *Makefile*. Below is an excerpt from the *Makefile*.

AWK = gawk
PCS\_AWK = ../bin/ICB\_PCS.awk
PCS\_CONF = ./axelx\_pcs\_phy\_cfg\_adaptive\_eval\_board.txt
#PCS\_CONF =
../../../register/axelx\_pcs\_phy\_cfg\_adaptive\_eval\_board.txt
#PCS\_CONF =
../../../register/axelx\_pcs\_phy\_cfg\_fixed\_eval\_board.txt

By default the on chip code is set up to use adaptive gain. If you wish to use fix gain comment out the line *"PCS\_CONF*"

axelx\_pcs\_phy\_cfg\_adaptive\_eval\_board.txt" and uncomment out the fixed gain line "PCS\_CONF axelx\_pcs\_phy\_cfg\_fixed\_eval\_board.txt".

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

Below is an example of a *Makefile* that uses fixed gain.

AWK = gawk
PCS\_AWK = ../bin/ICB\_PCS.awk
#PCS\_CONF = ./axelx\_pcs\_phy\_cfg\_adaptive\_eval\_board.txt
PCS\_CONF = ./register/axelx\_pcs\_phy\_cfg\_fixed\_eval\_board.txt

# Note: Please remember to assign the right path to these files. Without the correct path the *Makefile* will not compile properly.

For adaptive gain you do not need to modify any receiver co-efficient since they are determined automatically using the adaptive equalization algorithm, this is not the case for fixed gain. For fixed gain you need to modify the following the gain co-efficient. The file that need to be modified is *axelx\_pcs\_phy\_cfg\_fixed\_eval\_board.txt* and the procedure used to modify the fixed gain parameters can be found in *AXEL-X MB8AA3020 PCS Register Specification*.

#### 2.3.2.1 Configuring Transmit Pre-emphasis

The default transmit pre-emphasis parameters can be found in either axelx\_pcs\_phy\_cfg\_adaptive\_eval\_board.txt or

*axelx\_pcs\_phy\_cfg\_fixed\_eval\_board.txt* depending if the user is using fixed or adaptive gain. Below is an excerpt from the

*axelx\_pcs\_phy\_cfg\_adaptive\_eval\_board.txt* transmit pre-emphasis co-efficients for port 0. These transmit pre-emphasis co-efficients are optimized specifically for the AXEL-X evaluation board and may not be appropriate for all applications.

| PORT 00 |             |                | #@ Select port number (00~19 |                                                    |
|---------|-------------|----------------|------------------------------|----------------------------------------------------|
| # m     | ode         | value          | #-                           |                                                    |
| ]       | M1          | 5              | #-                           | Select adaptive mode.                              |
| # s     | tep ado     | dr data        | #-                           |                                                    |
| S2      | 0x0007      | 0x0001 #-      | PCS_CTL2                     | Select XAUI mode.                                  |
| S2      | 0xc002      | 0x000f #@      | 2 XL_LANE_SWAP_CTL           | Set Tx polarity swap.                              |
| S2      | 0xc003      | 0x86a0 #-      | PHY_PLL_MODE_CTL             | Set PHY PLL mode.                                  |
| S2      | 0xc000      | 0x00ff #-      | · PHY_PWR_DOWN_CTL           | Assert PHY Tx/Rx PD signals.                       |
| S2      | 0x0000      | 0x8000 #-      | PCS_CTL1                     | Reset PCS.                                         |
| S2      | 0xc010      | 0x03f0 #@      | PHY_TX0_EQ_CFG0              | Set Tx lane-0 tap-0 with $+63(0)$ .                |
| S2      | 0xc011      | 0x03f0 #@      | PHY_TX0_EQ_CFG1              | Set Tx lane-0 tap-1 with $+63(0)$ .                |
| S2      | 0xc012      | 0x0330 #@      | PHY_TX0_EQ_CFG2              | Set Tx lane-0 tap-2 with $+51(0)$ .                |
| S2      | 0xc013      | 0x13f1 #@      | PHY_TX0_EQ_CFG3              | Set Tx lane-0 tap-3 with -63(1).                   |
| S2      | 0xc014      | 0x0000 #@      | PHY_TX0_EQ_CFG4              | Set Tx lane-0 tap-4 with $+0(0)$ .                 |
| S2      | 0xc015      | 0x03f0 #@      | PHY_TX1_EQ_CFG0              | Set Tx lane-1 tap-0 with +63(0).                   |
| S2      | 0xc016      | 0x03f0 #@      | PHY_TX1_EQ_CFG1              | Set Tx lane-1 tap-1 with +63(0).                   |
| S2      | 0xc017      | 0x0330 #@      | PHY_TX1_EQ_CFG2              | Set Tx lane-1 tap-2 with $+51(0)$ .                |
| This    | document    | contains con   | idential information which   | shall not be reproduced or transferred to other    |
| docur   | ments or o  | disclosed to o | thers or used for manufa     | cturing or any other purpose without prior written |
| permi   | ission from | FUJITSU Ltd.   |                              |                                                    |

 S2
 0xc018
 0x13f1
 #@
 PHY\_TX1\_EQ\_CFG3
 Set
 Tx
 lane-1
 tap-3
 with
 -63(1).

 S2
 0xc019
 0x0000
 #@
 PHY\_TX1\_EQ\_CFG4
 Set
 Tx
 lane-1
 tap-3
 with
 +0(0).

 S2
 0xc01a
 0x03f0
 #@
 PHY\_TX2\_EQ\_CFG0
 Set
 Tx
 lane-2
 tap-0
 with
 +63(0).

 S2
 0xc01b
 0x03f0
 #@
 PHY\_TX2\_EQ\_CFG1
 Set
 Tx
 lane-2
 tap-1
 with
 +63(0).

 S2
 0xc01c
 0x0330
 #@
 PHY\_TX2\_EQ\_CFG2
 Set
 Tx
 lane-2
 tap-1
 with
 +63(0).

 S2
 0xc01d
 0x13f1
 #@
 PHY\_TX2\_EQ\_CFG2
 Set
 Tx
 lane-2
 tap-1
 with
 +63(1).

 S2
 0xc01d
 0x13f1
 #@
 PHY\_TX2\_EQ\_CFG3
 Set
 Tx
 lane-2
 tap-3
 with
 +63(1).

 S2
 0xc01d
 0x03f0
 #@
 PHY\_TX3\_EQ\_CFG4
 Set
 Tx
 lane-3
 tap-0
 with
 +63(0).

In order to modify these parameters please follow the procedure outlines in the AXEL-X MB8AA3020 PCS Register Specification.

#### 2.3.2.2 Configuring Transmit/Receive Lane and Polarity Swapping

By default the transmit polarity is swapped on the AXEL-X evaluation board for XAUI ports (i.e ports 0, 3-4, 7-19) and transmitter and receiver polarity are swapped for XFI ports (i.e ports 1, 2, 5, 6).

This may not be appropriate for all applications. In order to modify the lane or polarity swapping use XL LANE POLARITY SWAP CONTROL REGISTER (i.e 0xC002) as described in Table 49 of AXEL-X MB8AA3020 PCS Register Specification.

Below is an example where the transmit XAUI ports lanes are swapped but the transmit polarity is not swapped. This parameter can be found in both the *axelx\_pcs\_phy\_cfg\_adaptive\_eval\_board.txt* or *axelx\_pcs\_phy\_cfg\_fixed\_eval\_board.txt* file.

S2 0xc002 0x0030 #@ XL\_LANE\_SWAP\_CTL Set Tx polarity swap.

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

#### 2.3.2.3 Configuring the Port Configuration Register

By default all 10GBE ports are disabled with the generic firmware version. In order to enable the ports by default follow the instructions below.

Below is an excerpt from the file *ICB\_reg.asm*. In this file the first two .*data* fields of the pointer *ICB\_Default\_0* controls the Port Configuration Register (i.e base+000h) as described in *AXEL-X MB8AA3020 Register Specification*.

In order to change the port from the default disable state to a forwarding state bits [16:17] in the port configuration register needs to change from their current state of 00 to 11. This is illustrated below:

#### 2.3.3 Initializing GMII/MII Registers

The initialization of the MII/GMII interface is dependent on the user environment. By default the generic firmware version initialization sequence for the GBE interface is based on the AXEL-X evaluation board which has two external PHYs connected to the AXEL-X's MII/GMII ports. So by default the generic firmware initializes these two 10/100/GBE ports as GMII and assumes that there is an external PHY connected to these ports. While this is appropriate for the AXEL-X evaluation board it may not be suitable for all applications.

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

Below is an excerpt from the *Firmware.asm* file which shows the initialization of the two Ethernet ports to GMII.

The following configuration possibilities apply.

If the user wishes to modify both ports to MII the following modification needs to be performed:

#### Example: Both ports converted to MII

```
task24_bp4:
.data_ref ICB_Port_Core_0
.data 0x0a00
```

Only port 21 converted to MII but port 23 left as GMII the following modification needs to be done.

#### Example: Port 21 is MII Port 23 is GMII

task24\_bp4: .data\_ref ICB\_Port\_Core\_0 .data 0x0200

Port 21 is GMII but port 23 is MII the following modification needs to be done.

#### Example: Port 21 is GMII Port 23 is MII

task24\_bp4: .data\_ref ICB\_Port\_Core\_0 .data 0x0800

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

#### 2.3.3.1 External PHY Initialization

If external PHY are connected and the user wants to configure these PHYs in MII mode then the following modification must be performed.

Below is an excerpt of task28 and task29 responsible for MDIO ports found in the *Firmware.asm* file.

```
// -----
task28_bp3:
                  // MDIO Port-1
   // bp + 3
   .skip
   .data 0x0000 // Interface Core ICB
   .skip
   .data ref ICB MDIO GMII 0 // Interface ICB
// -----
task29_bp3:
                  // MDIO Port-2
   // bp + 3
   .skip
       0x0000 // Interface Core ICB
   .data
   .skip
   .data_ref ICB_MDIO_GMII_0 // Interface ICB
// _____
11
   Task Dependency
// ------
11
  MDIO-1 -> Port-21
11
  MDIO-2 -> Port-23
// -----
```

The default setting is for GMII however to convert from GMII to MII simply change the .data\_ref text from GMII to MII. Below is an example:

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

#### Example: Converting MDIO ports from GMII to MII

// \_\_\_\_\_ // MDIO Port-1 task28\_bp3: // bp + 3.skip .data 0x0000 // Interface Core ICB .skip .data\_ref ICB\_MDIO\_MII\_0 // Interface ICB // \_\_\_\_\_ task29\_bp3: // MDIO Port-2 // bp + 3 .skip 0x0000 // Interface Core ICB .data .skip .data\_ref ICB\_MDIO\_MII\_0 // Interface ICB // -----// Task Dependency // \_\_\_\_\_ // MDIO-1 -> Port-21 MDIO-2 -> Port-23 11 // \_\_\_\_\_

In addition to the PHY initialization the *ICB\_mdio.asm* file needs to be modified based on the PHY initialization sequence. This is especially true if the MDIO interface is connected to the PHY because the PHY address is embedded in the initialization code.

Using the AXEL-X evaluation board as an example port21 is polling PHY register 1 at PHY address 0 via MDIO-1 and port 23 is polling PHY register 1 at PHY address 0 via MDIO-2.

Below is an excerpt of the *Firmware.asm* showing this:

// ----task21\_bp3: // Task Port-21
// bp + 3: Port IRQ Service Required vector, Mode
.data 0x4003 // Use MDIO-0 for polling, Mode = 3
.data 0x0000 // Link up Check Threshold

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

By default the on chip code poll the PHY status check with link fault handler. This may not be appropriate for all situations because the user may not have a PHY or the MDIO may not be connected up to the PHY. If this is the case in then you will want to bypass the PHY status check by enabling Mode=2. Below is an example where the PHY status

#### Example of MDIO with PHY status disable

// ----task21\_bp3: // Task Port-21

// bp + 3: Port IRQ Service Required vector, Mode
.data 0x4002 // Use MDIO-0 for polling, Mode = 2
.data 0x0000 // Link up Check Threshold

// -----task23\_bp3: // Task Port-23

// bp + 3: Port IRQ Service Required vector, Mode
.data 0x8002 // Use MDIO-2 for polling, Mode = 2
.data 0x0000 // Link up Check Threshold
.data 0x0000

// -----

Lastly by default of the PHY address on the AXEL-X evaluation is 0 for both port 21 and port 23 however this is not universal for all design. In order to change this refer to *Firmware.asm* file *task21\_bp6* and *task\_23\_bp6*.

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

Below is an excerpt from this file:

#### 2.3.3 Initializing I2C Master Ports

Initialization of the I2C master ports is essential for proper operation of I2C master ports on AXEL-X chip. By default the on-chip code initializes I2C port 2 as the master but user may use both I2C ports 1 and port 2 as master ports which would require both to be initialized properly.

#### Note: No initialization of I2C slave ports is required.

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

### 3.0 Micro-Engine Description

Fujitsu MB8AA3020 10Gbps Ethernet switch uses an integrated 312.5 MHz core, 32KB RAM micro-engine to decoded micro-commands sent to the switch via a user designated Ethernet management interface. The micro-commands are encapsulated into an Ethernet frame and decoded by the micro-engine.

The use of the micro-engine gives users' the added flexibility in programming the MB8AA3020 and at the same time reducing software development time.

#### 3.1 Task Structure

There are a total of 32 individual tasks which are described in Table 3. The memory is context switched so each tasks uses the entire 2KBx64bytes of memory.

| Task Number | Thread Name  | Initial Task State | Description       |
|-------------|--------------|--------------------|-------------------|
| 0-19        | task_port    | Ready              | 10G port monitor  |
| 20          | task_none    | Sleep              | Reserved          |
| 21          | task_port_1g | Ready              | MII/GMII port     |
|             |              |                    | monitor           |
| 22          | task_none    | Sleep              | Reserved          |
| 23          | task_port_1g | Ready              | MII/GMII port     |
|             |              |                    | monitor           |
| 24          | Firmware     | Run                | Firmware Main     |
| 25          | task_none    | Sleep              | Reserved          |
| 26          | task_i2c     | Ready              | I2C Port-1        |
|             |              |                    | Handler           |
| 27          | task_i2c     | Ready              | I2C Port-2        |
|             |              |                    | Handler           |
| 28          | task_mdio    | Ready              | MDIO Port-1       |
|             |              |                    | Handler           |
| 29          | task_mdio    | Ready              | MDIO Port-2       |
|             |              |                    | Handler           |
| 30          | task_test    | Sleep              | For Firmware Test |
|             |              |                    | Purposes          |
| 31          | task_RTC     | Ready              | Real Time Clock   |

#### Table 3 Task Description

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

#### 3.2 MB8AA3020 Initialization Sequence

Shown in Figure 2 is the initialization sequence for the MB8AA3020 Fujitsu switch.



This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.



**Figure 2** Initialization Sequence

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

#### 3.3.1 Initialization Sequence for MII/GMII



Shown in Figure 3 is the initialization sequence for task\_[21:23] MII/GMII task.

Figure 3 Initialization Sequence for MII/GMII Task

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

#### 3.3.2 Initialization Sequence for 10GBE



Shown in Figure 4 is the initialization sequence for the 10GBE task.

Figure 4 Initialization Sequence for 10GBE Task

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.

# 4.0 Building MB8AA3020 Firmware Image

This section describes how to build the image for MB8AA3020. These same instructions can be found in the ReadMe file of the On-Chip-Code released with the chip.

### 4.1 Build Procedure

In order to compile the MB8AA3020 code the following is needed:

- MB8AA3020 on chip source code described above.
- MB8AA3020 Make file.
- GNU Compiler Collection (i.e gcc)

The procedure for building the MB8AA3020 firmware image is described below:

- 1. As stated in Section 2.3.1 Assigning MAC Addresses the user needs to assign an appropriate MAC address for the chip as well as each port. This is done by editing the *MAC\_address.asm* file.
- 2. Choose either fixed gain (i.e axel\_pcs\_phy\_cfg\_fixed\_eval\_board.txt) or adaptive gain (i.e axel\_pcs\_phy\_cfg\_adaptive\_eval\_board.txt) in the *Makefile*.
- 3. Type *make* on the command line.

Two files named *firmware.dat* and firmware.sym will be generated and placed in the *obj* directory. *Firmware.dat* is the file that will be downloaded into the MB8AA3020's EEPROM.

This document contains confidential information which shall not be reproduced or transferred to other documents or disclosed to others or used for manufacturing or any other purpose without prior written permission from FUJITSU Ltd.