

# Guide

**OS-9** for RadiSys

ENP-3510 Board

Version 3.2

#### www.radisys.com

World Headquarters
5445 NE Dawson Creek Drive • Hillsboro, OR
97124 USA
Phone: 503-615-1100 • Fax: 503-615-1121
Toll-Free: 800-950-0044

International Headquarters Gebouw Flevopoort • Televisieweg 1A NL-1322 AC • Almere, The Netherlands Phone: 31 36 5365595 • Fax: 31 36 5365620

RadiSys Microware Communications Software Division, Inc. 1500 N.W. 118th Street Des Moines, Iowa 50325 515-223-8000

Revision A December 2001

#### Copyright and publication information

This manual reflects version 3.2 of Enhanced OS-9 for IXP1200.

Reproduction of this document, in part or whole, by any means, electrical, mechanical, magnetic, optical, chemical, manual, or otherwise is prohibited, without written permission from RadiSys Microware Communications Software Division, Inc.

#### Disclaimer

The information contained herein is believed to be accurate as of the date of publication. However, RadiSys Corporation will not be liable for any damages including indirect or consequential, from use of the OS-9 operating system, Microware-provided software, or reliance on the accuracy of this documentation. The information contained herein is subject to change without notice.

#### Reproduction notice

The software described in this document is intended to be used on a single computer system. RadiSys Corporation expressly prohibits any reproduction of the software on tape, disk, or any other medium except for backup purposes. Distribution of this software, in part or whole, to any other party or on any other system may constitute copyright infringements and misappropriation of trade secrets and confidential processes which are the property of RadiSys Corporation and/or other parties. Unauthorized distribution of software may cause damages far in excess of the value of the copies involved.

December 2001 Copyright ©2001 by RadiSys Corporation. All rights reserved.

EPC, INtime, iRMX, MultiPro, RadiSys, The Inside Advantage, and ValuPro are registered trademarks of RadiSys Corporation. ASM, Brahma, DAI, DAQ, MultiPro, SAIB, Spirit, and ValuePro are trademarks of RadiSys Corporation

DAVID, MAUI, OS-9, and OS-9000, are registered trademarks of RadiSys Microware Communications Software Division, Inc. FasTrak, Hawk, SoftStax, and UpLink are trademarks of RadiSys Microware Communications Software Division, Inc.

# **Table of Contents**

| Chapter ' | 1: | Installing | and | Configuring | <b>OS-9</b> |
|-----------|----|------------|-----|-------------|-------------|
|-----------|----|------------|-----|-------------|-------------|

| 8  | Development Environment Overview                 |
|----|--------------------------------------------------|
| 9  | Requirements and Compatibility                   |
| 9  | Host Hardware Requirements (PC Compatible)       |
| 9  | Host Software Requirements (PC Compatible)       |
| 10 | Target Hardware Requirements                     |
| 11 | Target Hardware Setup                            |
| 11 | Installing the Flash Parts                       |
| 14 | Jumper Settings                                  |
| 15 | Connecting the Target to the Host                |
| 17 | Building the ROM Image                           |
| 17 | Coreboot                                         |
| 17 | Bootfile                                         |
| 18 | Using the Configuration Wizard                   |
| 19 | Creating the ROM Image                           |
| 19 | Creating the Coreboot Image                      |
| 19 | Creating the Bootfile Image                      |
| 20 | Building a Bootfile for the RadiSys ENP-3510     |
| 23 | Transferring the Bootfile to the Target          |
| 23 | Manually Configure Target                        |
| 25 | Testing the Ethernet Connection                  |
| 25 | Using FTP and pflash                             |
| 27 | Optional Procedures                              |
| 27 | Reprogramming the Flash Parts                    |
| 27 | Making a Coreboot Image with an EPROM programmer |
| 28 | Using the pflash Utility                         |

Creating a High-Level/Low-Level ROM Image

OS-9 for RadiSys ENP-3510 Board Guide

31

3

## **Chapter 2: Board Specific Reference**

| RadiSys.           |
|--------------------|
| MICROWARE SOFTWARE |

35

| 36 | Boot Options                             |
|----|------------------------------------------|
| 36 | Booting from Flash                       |
| 37 | Booting from on-Board Ethernet Interface |
| 37 | Booting over a Serial Port via kermit    |
| 37 | Restart Booter                           |
| 37 | Break Booter                             |
| 38 | Sample Boot Session and Messages         |
| 39 | The Fastboot Enhancement                 |
| 39 | Overview                                 |
| 40 | Implementation Overview                  |
| 40 | B_QUICKVAL                               |
| 40 | B_OKRAM                                  |
| 41 | B_OKROM                                  |
| 41 | B_1STINIT                                |
| 41 | B_NOIRQMASK                              |
| 42 | B_NOPARITY                               |
| 42 | Implementation Details                   |
| 42 | Compile-time Configuration               |
| 43 | Runtime Configuration                    |
| 44 | OS-9 Vector Mappings                     |
| 49 | Fast Interrupt Vector (0x7)              |
| 50 | GPIO Usage                               |
| 52 | Port Specific Utilities                  |
| 60 | Intel Work Bench Daemons                 |
| 60 | Dependencies                             |
| 63 | Example Daemon Start Up                  |
|    |                                          |

**Appendix A: Board Specific Modules** 

4

65

Low-Level System Modules 66 **High-Level System Modules** 67 **CPU Support Modules** 67

| 68          | System Configuration Module                     |    |
|-------------|-------------------------------------------------|----|
| 68          | Interrupt Controller Support                    |    |
| 68          | Real Time Clock                                 |    |
| 69          | Ticker                                          |    |
| 69          | Generic I/O Support Modules (File Managers)     |    |
| 70          | Pipe Descriptor                                 |    |
| 70          | RAM Disk Support                                |    |
| 70          | RAM Descriptors                                 |    |
| 70          | Serial and Console Devices                      |    |
| 71          | Descriptors for use with sc1100                 |    |
| 71          | Descriptors for use with scllio                 |    |
| 72          | SPF Device Support                              |    |
| 72          | PCI Support for NE2000 Compatibility            |    |
| 72          | spne2000 Descriptors                            |    |
| 72          | PCI Support for 3COM Ethernet cards             |    |
| 72          | spe509 Descriptors                              |    |
| 73          | PCI Support for Intel Ethernet Pro cards        |    |
| 73          | sppro100 Descriptors                            |    |
| 74          | PCI Support for DEC 211xx Ethernet cards        |    |
| 74          | sp21140 Descriptors                             |    |
| 74          | PCI Support for National DP83815 Ethernet Card  |    |
| 75          | spfa311 Descriptors                             |    |
| 75          | Network Configuration Modules                   |    |
| 76          | Common System Modules List                      |    |
| Appendix B: | Running OS-9 and the Intel® Developer Workbench | 79 |
| 80          | Overview                                        |    |
| 81          | Intel Developer Workbench                       |    |
| 82          | System Configuration                            |    |
| 83          | Running the Sample Project                      |    |
| 84          | Intel® Developer Workbench Interface Notes      |    |
|             |                                                 |    |

## **Product Discrepancy Report**

85

# **Chapter 1: Installing and Configuring**

**OS-9** 

This chapter describes installing and configuring OS-9 on the RadiSys ENP-3510 Embedded Network Processor. It includes the following sections:

- Development Environment Overview
- Requirements and Compatibility
- Target Hardware Setup
- Target Hardware Setup
- Connecting the Target to the Host
- Building the ROM Image
- Transferring the Bootfile to the Target
- Optional Procedures





# **Development Environment Overview**

**Figure 1-1** shows a typical development environment for the RadiSys ENP-3510. The components shown are the minimum required to develop software with OS-9 and the RadiSys ENP-3510.

Figure 1-1 ENP-3510 Development Environment



# **Requirements and Compatibility**



#### **Note**

Before you begin, install the *Enhanced OS-9 for IXP1200* CD-ROM on your host PC.

# **Host Hardware Requirements (PC Compatible)**

The host PC must have the following minimum hardware characteristics:

- 250MB of free hard disk space
- the recommended amount of RAM for the host operating system
- a CD-ROM drive
- a free serial port
- an Ethernet network card
- access to an Ethernet network

# **Host Software Requirements (PC Compatible)**

The host PC must have the following software installed:

- Enhanced OS-9
- Windows 95, Windows 98, Windows NT 4.0, Windows 2000, or Windows ME
- · terminal emulation program





#### **Note**

The examples in this document use the terminal emulation program Hyperterminal, which ships with all Windows operating systems.

## **Target Hardware Requirements**

Your reference board requires the following hardware:

- enclosure or chassis with power supply and backplane
- two OS-9 Flash parts
- an RS-232 null modem serial cable with 9-pin connectors
- access to an Ethernet network



#### **Note**

A crossover cable is required to connect the ENP-3510 control Ethernet port to a hub.

# **Target Hardware Setup**

# **Installing the Flash Parts**

Configuring your reference board consists of installing the Flash parts included in your *Enhanced OS-9 for IXP1200* product. The Flash parts include the minimum software required to get your board up and running OS-9 quickly. To install the Flash parts, complete the following steps:

- Step 1. With the target system powered down, remove the RadiSys ENP-3510 from the chassis. Lay the board on a flat, static-free surface.
- Step 2. You will need to remove the factory Flash parts from socket U17 and U25 (shown in Figure 1-2). To do this, unsnap the flash part gate by pressing on it to the right with your thumb. Once it is unsnapped, simply open the gate and remove the existing flash parts. (This procedure is diagramed in Figure 1-3.)



#### **WARNING**

Be careful not to damage the pins on the board or the Flash part. They are easily bent and extremely difficult to repair.



Figure 1-2 RadiSys ENP-3510



Step 3. Insert the OS-9 formatted flash parts into the appropriate sockets; U17 is the lower 16-bit socket and U25 is the upper 16-bit socket. In addition, the dimple on the flash part that indicates Pin 1 should line up with the asterisk symbol next to the socket on the target board. (See Figure 1-3 for more detail.)



#### **Note**

Be certain that each flash part is inserted correctly into the appropriate socket. If the parts are inserted improperly, the target will not boot.

Figure 1-3 Flash Part Setup



Step 4. Once the flash parts have been inserted, close the flash gate by snapping it shut.





#### **Note**

If you need to reprogram the Flash devices or create new Flash devices, see the **Optional Procedures** section.

# **Jumper Settings**

All jumper settings can remain as shipped from the factory. The jumpers are used only in conjunction with the factory Flash part—not the OS-9 Flash part.

# **Connecting the Target to the Host**

- Step 1. Connect the target system to a power supply. Make sure the power switch is in the OFF position.
- Step 2. Connect the target system to an Ethernet network. For a description see **Figure 1-1**.
- Step 3. Connect the target system to the host system using an RS-232 null modem serial cable with 9-pin connectors. For a description see **Figure 1-1**.
- Step 4. On the Windows desktop, click on the Start button and select Programs -> Accessories -> Hyperterminal.
- Step 5. Click the Hyperterminal icon.
- Step 6. Enter a name for your Hyperterminal session and select an icon for the new Hyperterminal session. Click OK. A new icon is created with the name of your session associated with it. The settings you choose for this session can be saved for future use.
- Step 7. In the **Connect To** dialog, go to the **Connect Using** box and select the communications port to be used to connect to the reference board.

  The port you select must be the same port that you inserted the actual cable into on your host machine.
- Step 8. Click OK.
- Step 9. In the **Properties** box, on the **Port Settings** tab, enter the following settings:

```
Bits per second = 38400

Data Bits = 8

Parity = None

Stop bits = 1

Flow control = None
```

Step 10. Click OK.



Figure 1-4 Port Settings



- Step 11. Go to the Hyperterminal menu and select Call -> Connect from the pull-down menu to establish your terminal session with the reference board. If you are connected, the bottom left of your Hyperterminal screen will display the word *connected*.
- Step 12. Turn on the target system. The OS-9 bootstrap message, followed by the OS-9 prompt, \$, is displayed in the Hyperterminal window.

At this point, your target system is running a basic OS-9 operating system from the OS-9 Flash part you inserted. Proceed through the following sections to create and download a more sophisticated OS-9 operating system.

# **Building the ROM Image**

The OS-9 ROM Image is a set of files and modules that collectively make up the OS-9 operating system. The specific ROM Image contents can vary from system to system depending on hardware capabilities and user requirements.

To simplify the process of loading and testing OS-9, the ROM Image is generally divided into two parts—the low-level image, called coreboot; and the high-level image, called bootfile.

## Coreboot

The coreboot image is generally responsible for initializing hardware devices and locating the high-level (or bootfile) image as specified by its configuration. Depending on hardware capabilities, the bootfile image could be found on a Flash part, a hard disk, or on an Ethernet network. It is also responsible for building basic structures based on the image it finds and passing control to the kernel to bring up the OS-9 system.

## **Bootfile**

The bootfile image contains the kernel and other high-level modules (initialization module, file managers, drivers, descriptors, and applications). The image is loaded into memory based on the device selected from the boot menu. The bootfile image normally brings up an OS-9 shell prompt, but can be configured to automatically start an application.

Microware provides a Configuration Wizard to create a coreboot image, a bootfile image, or an entire OS-9 ROM Image. The wizard can also be used to modify an existing image. The Configuration Wizard is automatically installed on your host PC during the installation process.



# **Using the Configuration Wizard**

To use the Configuration Wizard, perform the following steps:

- Step 1. Click the Start button on the Windows desktop.
- Step 2. Select Programs -> Microware -> Enhanced OS-9 for IXP1200 -> Microware Configuration Wizard. You should see the following opening screen:

Figure 1-5 IXP1200 Configuration Wizard



- Step 3. Select the path where the MWOS directory structure can be located by clicking the MWOS location button.
- Step 4. Select the target board from the Port Selection pull-down menu.
- Step 5. Select a name for your configuration in the Configuration Name field. Your settings will be saved for future use. This enables you to modify the ROM image incrementally, without having to reselect every option for each change.

Step 6. Select Advanced Mode and click OK. The Main Configuration window is displayed. Advanced Mode enables you to make more detailed and specific choices about what modules are included in your ROM image.

# **Creating the ROM Image**

The ROM Image consists of the coreboot image (low-level system files) and the bootfile image (high-level system files). Together these files comprise the OS-9 operating system. The Configuration Wizard enables you to choose the contents of your OS-9 implementation. It also enables you to create individual coreboot and bootfile images, or combine them into a single file—called the ROM Image.

## **Creating the Coreboot Image**

The OS-9 Flash part shipped with Enhanced OS-9 for IXP1200 3.0 include a working coreboot image. No modifications are necessary in the Configuration Wizard.

## **Creating the Bootfile Image**

The default settings in the Configuration Wizard have been preset for optimum performance for the RadiSys ENP-3510 Embedded Network Processor. The only modifications required are to enable networking and to change the network settings. The network settings information must be obtained from your network administrator.

To configure your system for networking, complete the following steps:



# **Building a Bootfile for the RadiSys ENP-3510**

Step 1. From the wizard's main configuration window, select Configure -> Bootfile -> NetWork Configuration. The following dialog window should appear.

Figure 1-6 Network Configuration—Interface Tab



Step 2. Configure your system as shown in **Figure 1-6**. The **IP Address**, **IP Broadcast Address**, and **Subnet Mask** addresses must be obtained from your network administrator.

Step 3. Select the **SoftStax Setup** tab. The following dialog window should appear:

Figure 1-7 Network Configuration—SoftStax Setup Tab



- Step 4. Configure your system as shown in Figure 1-7.
- Step 5. Leave the other **Network Configuration** options at the default settings. Click OK.



#### Note

Other **Network Configuration** options can be changed in this dialog according to your specific requirements and your network.

Step 6. Select Configure -> Build Image. The **Master Builder** dialog window appears.



Figure 1-8 Master Builder Dialog Window



- Step 7. Configure your Master Builder options as shown in Figure 1-8.
- Step 8. Click Build. This builds a bootfile image that can be placed on the target. The bootfile image, os9kboot, is stored in the following default location:

\mwos\OS9000\ARMV4\PORTS\IXP1200\BOOTS\INSTALL\PORTBOOT\

Clicking Save As after the build operation is optional; it enables you to save the bootfile image to a location of your choice.



#### **WARNING**

Do not select **Coreboot Only Image** or **Coreboot + Bootfile** at this time. Selecting these options will cause the supplied coreboot image in the OS-9 Flash part to be overwritten. Any errors made during coreboot image modification or during reburning of the Flash part can result in a non-bootable RadiSys ENP-3510.

# Transferring the Bootfile to the Target

The following procedures describe transferring the bootfile image from the host system to the target system. The following basic steps are included:

- manually configure target settings
- using File Transfer Protocol (FTP) and the OS-9 pflash utility to transfer the bootfile image from the host system to the target system

# **Manually Configure Target**

The software shipped on the OS-9 Flash parts includes basic networking functionality. The basic network settings include address fields that must be reconfigured for your particular network. In addition, an area of the target system's Flash must be initialized. Complete the following procedure to manually configure the target.



#### **Note**

The following procedure enables your system to perform FTP. Once the new bootfile is transferred from the host to the RadiSys ENP-3510 (via FTP), the settings do not have to be manually configured again.

- Step 1. Open the RadiSys ENP-3510 Hyperterminal window on the Windows host desktop.
- Step 2. Install the network buffer allocation software on the RadiSys ENP-3510 target system by typing the following command:

\$ mbinstall



Step 3. Initialize a RAM Disk to temporarily hold the image to be flashed by typing the following command:

```
$ iniz /r1
```

Step 4. Initialize the networking modules by typing the following command:

```
$ ipstart
```

Step 5. Configure the network interface parameters and add entries to the routing table by typing the following commands:

```
$ ifconfig enet() x.x.x.x netmask y.y.y.y broadcast y1.y1.y1
$ route delete default
$ route add default z.z.z.z
```



#### **Note**

The placeholders listed above represent the following items:

x.x.x.x is the IP address assigned to the RadiSys ENP-3510 y.y.y.y is the subnet mask address.

y1.y1.y1.y1 is the IP Broadcast for your network.

z.z.z.z is the IP Gateway address.

This information must be supplied by your network administrator.

Step 6. Start the internet process server by typing the following command:

```
$ inetd<>>>/nil&
```

Step 7. Change the current directory on the target by typing the following command:

```
$ chd /r1
```

## **Testing the Ethernet Connection**

To confirm that your host and target can communicate over Ethernet, perform the following steps.

- Step 1. Open a DOS shell on the host system.
- Step 2. At the prompt type the following command:

```
ping <IP address of target>.
```

The IP Address is the address you assigned to the target board and is typed without the <> brackets.

If the ping was successful, you will see the following response:

```
Reply from <IP Address>: bytes=xx time =xms TTL= xx
```

If the ping was unsuccessful, you will see the following response: Request timed out.

# **Using FTP and pflash**

Complete the following procedure to transfer the bootfile image from the host system to the target system. It is assumed that you have completed the steps described previously in this manual and that the target is connected to an Ethernet network and is booted up.

- Step 1. Start a DOS shell on the host system.
- Step 2. Change directories to where the bootfile image, os9kboot, is located. The default location for this file is in the following directory:

\mwos\OS9000\ARMV4\PORTS\IXP1200\BOOTS\INSTALL\PORTBOOT\

Step 3. At the prompt type the following command:

```
ftp <IP address of target>
```



Step 4. At the ftp> prompt type the following command:

bin

This designates binary format.

Step 5. At the ftp> prompt type the following command:

put os9kboot

The os9kboot file is transferred to the target's RAM disk (/r1).

- Step 6. Open the RadiSys ENP-3510 Hyperterminal window on the Windows host desktop.
- Step 7. From the OS-9 prompt (\$) type the following command:

\$ pflash -f=/r1/os9kboot

pflash is configured to copy the os9kboot file to the correct address.



#### For More Information

The pflash utility is documented in the **Port Specific Utilities** section of **Chapter 2**.

# **Optional Procedures**

# **Reprogramming the Flash Parts**

If you want to use ROM Ethernet services such as System State Debugging, you must create a new coreboot image. The coreboot image that was shipped in the OS-9 Flash parts with the reference board does not allow you to perform System State Debugging because the IP address in Flash ROM is set to "0.0.0.0". You can create the coreboot image with an EPROM programmer.



#### **Note**

Re-creating the Coreboot image is required only when system state debugging is desired.

## Making a Coreboot Image with an EPROM programmer

This section describes creating the coreboot image. When you are done creating the coreboot image, please refer to your EPROM programmer's instructions to learn how to load the coreboot image into the EPROM.

- Step 1. Click the Start button on the Windows desktop.
- Step 2. Select Programs -> Microware -> Enhanced OS-9 IXP1200 -> Microware Configuration Wizard. The Configuration Wizard opening screen is displayed (Figure 1-5).
- Step 3. Give the image a name in the **Configuration Name** field.
- Step 4. Select Advanced Mode and click OK. The configuration screen is displayed.
- Step 5. Make any necessary changes to the coreboot image settings.



- Step 6. Select Configure -> Build Image to display the **Master Builder** screen.
- Step 7. Select the Coreboot Only Image setting and click Build.
- Step 8. Click Save As to save the coreboot image to a directory of your choosing. If you do not have that directory on the drive, you can create it.
- Step 9. Transfer the coreboot image to the EPROM with the EPROM programmer. You will need to follow the documentation for the EPROM programmer to complete this step.

## **Using the pflash Utility**

This section describes creating a new coreboot image and burning into Flash using the OS-9 pflash utility. When you are done creating the coreboot image, you will use FTP and pflash to place the new image into the target system's Flash.



#### **WARNING**

Using the OS-9 pflash utility to program a new coreboot image into Flash can damage the Flash parts. Any errors made during coreboot image modification or during reburning of the Flash part can result in a non-bootable RadiSys ENP-3510.

- Step 1. Click the Start button on the Windows desktop.
- Step 2. Select Programs -> Microware -> Enhanced OS-9 IXP1200 -> Microware Configuration Wizard. The configuration wizard opening screen is displayed (Figure 1-5).
- Step 3. Give the image a name in the **Configuration Name** field.

- Step 4. Select Advanced Mode and click OK. The configuration screen is displayed.
- Step 5. Make any necessary changes to the coreboot image settings.

The coreboot options can be found under the Configure -> Coreboot -> Main Configuration and the Configure -> Coreboot -> Disk Configuration dialog boxes. These options enable you to set low-level networking information, select a communication protocol, etc.

All high-level, bootfile options can be left at the default settings.

- Step 6. Select Configure -> Build Image to display the Master Builder screen.
- Step 7. Select the Coreboot Only Image + Bootfile setting and click Build.
- Step 8. Click Save As to save the coreboot image to a directory of your choosing. If you do not have that directory on the drive, you can create it.

The default location for this file is in the following directory:

\mwos\OS9000\ARMV4\PORTS\IXP1200\BOOTS\INSTALL\PORTBOOT\

- Step 9. Start a DOS shell on the host system.
- Step 10. Change directories to where the bootfile image, rom, is located. The default location for this file is in the following directory:

\mwos\OS9000\ARMV4\PORTS\IXP1200\BOOTS\INSTALL\PORTBOOT\

Step 11. At the prompt type the following command:

ftp <IP address of target>

Step 12. At the ftp> prompt type the following command:

bin

This designates binary format.

Step 13. At the ftp> prompt type the following command:

put rom

The os9kboot file is transferred to the target's RAM disk (/r1).



- Step 14. Open the RadiSys ENP-3510 Hyperterminal window on the Windows host desktop.
- Step 15. From the OS-9 prompt (\$) type the following command:

$$$ pflash -f=/r1/rom$$

The file is transferred to the target system's Flash memory. pflash is configured to copy the rom file to the correct address.

# Creating a High-Level/Low-Level ROM Image

The following procedures describe how to configure a ROM image that supports both a low-level (for Hawk system-state debugging) and high-level (for Hawk user-state debugging and Intel<sup>®</sup> Developer Workbench usage) configuration. Complete the following steps to create this image:



#### **WARNING**

Using the OS-9 pflash utility to program a new coreboot image into Flash can damage the Flash parts. Any errors made during coreboot image modification or during reburning of the Flash part can result in a non-bootable RadiSys ENP-3510.



#### Note

These procedures assume that you have already completed the procedures described in the **Building the ROM Image** and **Transferring the Bootfile to the Target** sections.

Step 1. In the main configuration window of the wizard, select Configure -> Coreboot -> Main Configuration. Select the **Ethernet** tab.

Enable the Add to Boot Menu check box.

Step 2. Select Configure -> Bootfile -> Disk Configuration. Select the **Init Options** tab.

Select the Mshell radio button.

Select the **/dd** radio button.

Select the **User** radio button, and remove the following string from the Parameter List:

mbinstall ;ipstart; inetd <>>>/nil&;



Step 3. Select Sources -> Port -> User. Add the following lines:

```
* hlproto provides user level code access to protoman
./../../../../ARMV4/CMDS/BOOTOBJS/ROM/hlproto

*
* low-level user-state debugging modules
../../../../ARMV4/CMDS/undpd
../../../../ARMV4/CMDS/undpdc

*
* sndp - Hawk system-state debug client module
../../../../ARMV4/CMDS/BOOTOBJS/ROM/sndp
```

Step 4. Select Configure -> Build. The Master Builder Dialog window appears.

Enable the User State Debugging Modules box.

Select the **Coreboot + Bootfile** radio button.

- Step 5. Click Build.
- Step 6. Start a DOS shell on the host system.
- Step 7. Change directories to where the OS-9 ROM image, rom, is located. The default location for this file is in the following directory:

\mwos\OS9000\ARMV4\PORTS\IXP1200\BOOTS\INSTALL\PORTBOOT\

Step 8. At the prompt type the following command:

```
ftp <IP address of target>
```

Step 9. At the ftp> prompt type the following command:

bin

This designates binary format.

Step 10. At the ftp> prompt type the following command:

```
put rom
```

The OS-9 ROM image is transferred to the target's RAM disk (/r1).

Step 11. Open the RadiSys ENP-3510 Hyperterminal window on the Windows host desktop.

## Step 12. From the OS-9 prompt (\$) type the following command:

```
$ pflash -ri -f=/r1/rom
```

The OS-9 ROM image is transferred to the target system's Flash memory. pflash is configured to copy the file to the correct address.

The target system now contains all necessary modules for both a high-level and low-level configuration. However, these configurations can not be used simultaneously. As the target system is booted up, you must choose between a high-level or low-level configuration according to your needs. The following commands must be entered at the OS-9 prompt after booting for each configuration:

Low-Level Configuration Procedures

```
$ p2init hlproto
$ p2init sndp
$ undpd <>>>/nil&
```

High-Level Configuration Procedures

```
$ mbinstall
$ ipstart
$ inetd<>>>/nil&
$ spfndpd <>>>/nil&
```



#### Note

The low- and high-level ethernet drivers cannot be initialized at the same time. If you want simultaneous support for both system-state debugging and user-state debugging, you have the following options:

- Use low-level SLIP for system-state debugging.
- Use RomBug for system-state debugging.
- Configure high-level debugging without high-level ethernet support.



# **Chapter 2: Board Specific Reference**

This chapter contains porting information that is specific to the RadiSys ENP-3510 Embedded Network Processor. It includes the following sections:

- Boot Options
- The Fastboot Enhancement
- OS-9 Vector Mappings
- GPIO Usage
- Port Specific Utilities
- Intel Work Bench Daemons



## For More Information

For general information on porting OS-9, see the *OS-9 Porting Guide*.





# **Boot Options**

The default boot options for the RadiSys ENP-3510 are listed below. The boot options can be selected by hitting the space bar during system bootup when the following message appears on the serial console:

Now trying to Override autobooters

The configuration of these booters can be changed by altering the default.des file, which is located in the following directory:

mwos\OS9000\ARMV4\PORTS\IXP1200\ROM

Booters can be configured to be either menu or auto booters. The auto booters automatically attempt to boot in the same order as listed in the auto booter array. Menu booters from the defined menu booter array are chosen interactively from the console command line after the boot menu is displayed.

# **Booting from Flash**

When the  $rom\_cnfg.h$  file has a ROM search list defined, the options ro and lr appear in the boot menu. If no search list is defined N/A appears in the boot menu. If an OS-9 bootfile is programmed into Flash memory in the address range defined in the port's default.des file, the system can boot and run from Flash.

rom\_cnfg.h is located in the following directory:

mwos\os9000\ARMV4\PORTS\IXP1200\ROM\ROMCORE

ro ROM boot—the system runs from the

Flash bank.

1r load to RAM—the system copies the

Flash image into RAM and runs from

there.

## **Booting from on-Board Ethernet Interface**

The system can boot using the BootP protocol with an Ethernet IntelPro 100 and eb option.

eb Ethernet boot—a PCI card that supports

Ethernet will use the bootp protocol to transfer a bootfile into RAM and the

systems runs from there.

## **Booting over a Serial Port via kermit**

The system can download a bootfile in binary form over its serial port at speeds up to 115200 using the kermit protocol. The speed of this transfer depends of the size of the bootfile, but it usually takes at least three minutes to complete. Dots on the console will show the progress of the boot.

ker kermit boot—the os9kboot file is sent

via the kermit protocol into system RAM

and runs from there.

### **Restart Booter**

The restart booter enables a way to restart the bootstrap sequence.

q quit—quit and attempt to restart the

booting process.

### **Break Booter**

The break booter allows entry to the system level debugger (if one exists). If the debugger is not in the system the system will reset.

break break and enter the system level

debugger rombug.



## **Sample Boot Session and Messages**

Following is an example boot of the RadiSys ENP-3510 using the 1r boot option.

```
OS-9 Bootstrap for the ARM (Edition 64)
Now trying to Override autobooters.
Press the spacebar for a booter menu
BOOTING PROCEDURES AVAILABLE ----- <INPUT>
Boot embedded OS-9 in-place ----- <bo>
Copy embedded OS-9 to RAM and boot - <lr>
Load bootfile via kermit Download ---- <ker>
Enter system debugger ----- <break>
Restart the System ----- <q>
Select a boot method from the above menu: lr
Now searching memory ($00040000 - $001fffff) for an OS-9
Kernel...
An OS-9 kernel was found at $00040000
A valid OS-9 bootfile was found.
$ pciv
BUS:DV:FU VID DID CMD STAT CLASS RV CS IL IP
000:00:00 8086 1200 0017 2200 0b4001 00 00 6e 0e IXP1200
Processor [S]
000:05:00 11ad 0002 0007 0280 020000 20 00 6e 01 Network
Controller [S]
$ ipstart
$ ping 172.16.3.202
PING 172.16.3.202 (172.16.3.202): 56 data bytes
64 bytes from 172.16.3.202: ttl=255 time=10 ms
```

## The Fastboot Enhancement

The Fastboot enhancements to OS-9 provide faster system bootstrap performance to embedded systems. The normal bootstrap performance of OS-9 is attributable to its flexibility. OS-9 handles many different runtime configurations to which it dynamically adjusts during the bootstrap process.

The Fastboot concept consists of informing OS-9 that the defined configuration is static and valid. These assumptions eliminate the dynamic searching OS-9 normally performs during the bootstrap process and enables the system to perform a minimal amount of runtime configuration. As a result, a significant increase in bootstrap speed is achieved.

#### **Overview**

The Fastboot enhancement consists of a set of flags that control the bootstrap process. Each flag informs some portion of the bootstrap code that a particular assumption can be made and that the associated bootstrap functionality should be omitted.

The Fastboot enhancement enables control flags to be statically defined when the embedded system is initially configured as well as dynamically altered during the bootstrap process itself. For example, the bootstrap code could be configured to query dip switch settings, respond to device interrupts, or respond to the presence of specific resources which would indicate different bootstrap requirements.

In addition, the Fastboot enhancement's versatility allows for special considerations under certain circumstances. This versatility is useful in a system where all resources are known, static, and functional, but additional validation is required during bootstrap for a particular instance, such as a resource failure. The low-level bootstrap code may respond to some form of user input that would inform it that additional checking and system verification is desired.



## **Implementation Overview**

The Fastboot configuration flags have been implemented as a set of bit fields. An entire 32-bit field has been dedicated for bootstrap configuration. This four-byte field is contained within the set of data structures shared by the ModRom sub-components and the kernel. Hence, the field is available for modification and inspection by the entire set of system modules (high-level and low-level). Currently, there are six bit flags defined with eight bits reserved for user-definable bootstrap functionality. The reserved user-definable bits are the high-order eight bits (31-24). This leaves bits available for future enhancements. The currently defined bits and their associated bootstrap functionality are listed below:

### **B\_QUICKVAL**

The B\_QUICKVAL bit indicates that only the module headers of modules in ROM are to be validated during the memory module search phase. This causes the CRC check on modules to be omitted. This option is a potential time saver, due to the complexity and expense of CRC generation. If a system has many modules in ROM, where access time is typically longer than RAM, omitting the CRC check on the modules will drastically decrease the bootstrap time. It is rare that corruption of data will ever occur in ROM. Therefore, omitting CRC checking is usually a safe option.

#### **B OKRAM**

The B\_OKRAM bit informs both the low-level and high-level systems that they should accept their respective RAM definitions without verification. Normally, the system probes memory during bootstrap based on the defined RAM parameters. This allows system designers to specify a possible RAM range, which the system validates upon startup. Thus, the system can accommodate varying amounts of RAM. In an embedded system where the RAM limits are usually statically defined and presumed to be functional, however, there is no need to validate the defined RAM list. Bootstrap time is saved by assuming that the RAM definition is accurate.

### **B OKROM**

The B\_OKROM bit causes acceptance of the ROM definition without probing for ROM. This configuration option behaves like the B\_OKRAM option, except that it applies to the acceptance of the ROM definition.

### **B\_1STINIT**

The B\_1STINIT bit causes acceptance of the first init module found during cold-start. By default, the kernel searches the entire ROM list passed up by the ModRom for init modules before it accepts and uses the init module with the highest revision number. In a statically defined system, time is saved by using this option to omit the extended init module search.

### **B\_NOIRQMASK**

The B\_NOIRQMASK bit informs the entire bootstrap system that it should not mask interrupts for the duration of the bootstrap process. Normally, the ModRom code and the kernel cold-start mask interrupts for the duration of the system startup. However, some systems that have a well defined interrupt system (i.e. completely calmed by the sysinit hardware initialization code) and also have a requirement to respond to an installed interrupt handler during system startup can enable this option to prevent the ModRom and the kernel cold-start from disabling interrupts. This is particularly useful in power-sensitive systems that need to respond to "power-failure" oriented interrupts.



#### **Note**

Some portions of the system may still mask interrupts for short periods during the execution of critical sections.



### **B\_NOPARITY**

If the RAM probing operation has not been omitted, the B\_NOPARITY bit causes the system to not perform parity initialization of the RAM. Parity initialization occurs during the RAM probe phase. The B\_NOPARITY option is useful for systems that either require no parity initialization at all or systems that only require it for "power-on" reset conditions. Systems that only require parity initialization for initial "power-on" reset conditions can dynamically use this option to prevent parity initialization for subsequent "non-power-on" reset conditions.

## **Implementation Details**

This section describes the compile-time and runtime methods by which the bootstrap speed of the system can be controlled.

## **Compile-time Configuration**

The compile-time configuration of the bootstrap is provided by a pre-defined macro (BOOT\_CONFIG), which is used to set the initial bit-field values of the bootstrap flags. You can redefine the macro for recompilation to create a new bootstrap configuration. The new over-riding value of the macro should be established by redefining the macro in the rom\_config.h header file or as a macro definition parameter in the compilation command.

The rom\_config.h header file is one of the main files used to configure the ModRom system. It contains many of the specific configuration details of the low-level system. Below is an example of how you can redefine the bootstrap configuration of the system using the BOOT\_CONFIG macro in the rom\_config.h header file:

```
#define BOOT_CONFIG (B_OKRAM + B_OKROM + B_QUICKVAL)
```

Below is an alternate example showing the default definition as a compile switch in the compilation command in the makefile:

```
SPEC_COPTS = -dNEWINFO -dNOPARITYINIT -dBOOT_CONFIG=0x7
```

This redefinition of the BOOT\_CONFIG macro results in a bootstrap method that accepts the RAM and ROM definitions without verification, and also validates modules solely on the correctness of their module headers.

## **Runtime Configuration**

The default bootstrap configuration can be overridden at runtime by changing the rinf->os->boot\_config variable from either a low-level P2 module or from the sysinit2() function of the sysinit.c file. The runtime code can query jumper or other hardware settings to determine what user-defined bootstrap procedure should be used. An example P2 module is shown below.



#### **Note**

If the override is performed in the sysinit2() function, the effect is not realized until after the low-level system memory searches have been performed. This means that any runtime override of the default settings pertaining to the memory search must be done from the code in the P2 module code.

```
#define NEWINFO
#include <rom.h>
#include <types.h>
#include <const.h>
#include <errno.h>
#include <romerrno.h>
#include <p2lib.h>

error_code p2start(Rominfo rinf, u_char *glbls)
{
    /* if switch or jumper setting is set... */
    if (switch_or_jumper == SET) {
        /* force checking of ROM and RAM lists */
        rinf->os->boot_config &= ~(B_OKROM+B_OKRAM);
    }
    return SUCCESS;
}
```



# **OS-9 Vector Mappings**

This section contains the OS-9 vector mappings for the RadiSys ENP-3510 Embedded Network Processor.

The ARM standard defines exceptions 0x0-0x7. The OS-9 system maps these one-to-one. External interrupts from vector 0x6 are expanded to the virtual vector rage shown below by the <code>irqixp1200</code> module.



#### For More Information

See the *RadiSys ENP-3510 Network Processor Programer's Reference* for further information on individual sources.

### Table 2-1 OS-9 IRQ Assignment for the RadiSys ENP-3510

| OS-9 IRQ # | ARM Function                  |
|------------|-------------------------------|
| 0x0        | Processor Reset               |
| 0x1        | Undefined Instruction         |
| 0x2        | Software Interrupt            |
| 0x3        | Abort on Instruction Prefetch |
| 0x4        | Abort on Data Access          |
| 0x5        | Unassigned/Reserved           |
| 0x6        | External Interrupt            |

Table 2-1 OS-9 IRQ Assignment for the RadiSys ENP-3510

| OS-9 IRQ # | ARM Function                       |  |
|------------|------------------------------------|--|
| 0x7        | Fast Interrupt                     |  |
| 0x8        | Alignment error Form of Data abort |  |

Table 2-2 RadiSys ENP-3510 Specific Functions

| OS-9 IRQ # | ENP-3510 Specific Function                       |  |
|------------|--------------------------------------------------|--|
| 0x40       | MicroEngine 0, thread 0 (FBI block sources 0-28) |  |
| 0x41       | MicroEngine 0, thread 1                          |  |
| 0x42       | MicroEngine 0, thread 2                          |  |
| 0x43       | MicroEngine 0, thread 3                          |  |
| 0x44       | MicroEngine 1, thread 0                          |  |
| 0x45       | MicroEngine 1, thread 1                          |  |
| 0x46       | MicroEngine 1, thread 2                          |  |
| 0x47       | MicroEngine 1, thread 3                          |  |
| 0x48       | MicroEngine 2, thread 0                          |  |
| 0x49       | MicroEngine 2, thread 1                          |  |
| 0x4a       | MicroEngine 2, thread 2                          |  |
| 0x4b       | MicroEngine 2, thread 3                          |  |



Table 2-2 RadiSys ENP-3510 Specific Functions (continued)

| OS-9 IRQ # | ENP-3510 Specific Function        |  |
|------------|-----------------------------------|--|
| 0x4c       | MicroEngine 3, thread 0           |  |
| 0x4d       | MicroEngine 3, thread 1           |  |
| 0x4e       | MicroEngine 3, thread 2           |  |
| 0x4f       | MicroEngine 3, thread 3           |  |
| 0x50       | MicroEngine 4, thread 0           |  |
| 0x51       | MicroEngine 4, thread 1           |  |
| 0x52       | MicroEngine 4, thread 2           |  |
| 0x53       | MicroEngine 4, thread 3           |  |
| 0x54       | MicroEngine 5, thread 0           |  |
| 0x55       | MicroEngine 5, thread 1           |  |
| 0x56       | MicroEngine 5, thread 2           |  |
| 0x57       | MicroEngine 5, thread 3           |  |
| 0x58       | Debug interrupt 0                 |  |
| 0x59       | Debug interrupt 1                 |  |
| 0x5a       | Debug interrupt 2                 |  |
| 0x5b       | CINT pin                          |  |
| 0x5c       | Reserved (PCI block sources 0-32) |  |

Table 2-2 RadiSys ENP-3510 Specific Functions (continued)

| OS-9 IRQ # | ENP-3510 Specific Function |  |
|------------|----------------------------|--|
| 0x5d       | Soft Interrupt             |  |
| 0x5e       | Reserved                   |  |
| 0x5f       | Reserved                   |  |
| 0x60       | Timer 1                    |  |
| 0x61       | Timer 2                    |  |
| 0x62       | Timer 3                    |  |
| 0x63       | Timer 4                    |  |
| 0x64       | Reserved                   |  |
| 0x65       | Reserved                   |  |
| 0x66       | Reserved                   |  |
| 0x67       | Reserved                   |  |
| 0x68       | Reserved                   |  |
| 0x69       | Reserved                   |  |
| 0x6a       | Reserved                   |  |
| 0x6b       | Door Bell from host        |  |
| 0x6c       | DMA channel 1              |  |
| 0x6d       | DMA channel 2              |  |



Table 2-2 RadiSys ENP-3510 Specific Functions (continued)

| OS-9 IRQ# | ENP-3510 Specific Function          |  |
|-----------|-------------------------------------|--|
| 0x6e      | PCI_IRQ_1 (External PCI interrupts) |  |
| 0x6f      | Reserved                            |  |
| 0x70      | DMA1 not busy                       |  |
| 0x71      | DMA2 not busy                       |  |
| 0x72      | Start BIST                          |  |
| 0x73      | Received SERR                       |  |
| 0x74      | Reserved                            |  |
| 0x75      | I20 inbound post_list               |  |
| 0x76      | Power management                    |  |
| 0x77      | Discard timer expired               |  |
| 0x78      | Data parity error detected          |  |
| 0x79      | Received master abort               |  |
| 0x7a      | Received target abort               |  |
| 0x7b      | Detected PCI Parity error           |  |
| 0x7c      | SRAM interrupt (SRAM block source)  |  |
| 0x7d      | RTC (RTC block source)              |  |

Table 2-2 RadiSys ENP-3510 Specific Functions (continued)

| OS-9 IRQ # | ENP-3510 Specific Function |  |
|------------|----------------------------|--|
| 0x7e       | SDRAM (SDRAM block source) |  |
| 0x7f       | UART (UART block source)   |  |

## **Fast Interrupt Vector (0x7)**

The ARM4 defined fast interrupt (FIQ) mapped to vector 0x7 is handled differently by the OS-9 interrupt code and can not be used as freely as the external interrupt mapped to vector 0x6. To make fast interrupts as quick as possible for extremely time critical code, no context information is saved on exception (except auto hardware banking) and FIQs are never masked. This requires any exception handler to save and restore its necessary context if the FIQ mechanism is to be used. This requirement means that a FIQ handler's entry and exit points must be in assembly, as the C compiler will make assumptions about context. In addition, no system calls are possible unless a full C ABI context save has been performed first. The OS-9 IRQ code for the SA1100 has assigned all interrupts as normal external interrupts. It is up to the user to re-define a source as an FIQ to make use of this feature.



# **GPIO** Usage

The RadiSys ENP-3510 has four GPIO pins. Each is connected to jumpers on the board. The IXP1200 GPIO unit is somewhat unique in that the GPIOs can be "owned" by either the StrongARM core or by the FBI unit. The owner of the GPIOs dictates their usability and function. The OS-9 boot code assigns all GPIOs to the StrongARM core and sets them up as inputs.



### **For More Information**

See the *ENP-3510 Network Processor Programer's Reference* for more information.

Table 2-3 GPIO Usage for the RadiSys ENP-3510

| GPIO  | Signal Name | Direct | Description           |
|-------|-------------|--------|-----------------------|
| GPIO0 | CPU_GPIO_0  | Input  | Value of switch SW2-1 |
| GPIO1 | CPU_GPIO_1  | Input  | Value of switch SW2-2 |
| GPIO2 | CPU_GPIO_2  | Input  | Value of switch SW2-3 |
| GPIO3 | CPU_GPIO_3  | Input  | Value of switch SW2-4 |

When the FBI unit owns particular GPIO pins, it indicates a certain MAC mode.

**Table 2-4 MAC Modes** 

| FBI owns GPIO # | MAC Mode                            |
|-----------------|-------------------------------------|
| None 3-4        | MAC mode, 64-bit bidirectional mode |
| GPIO [0] 1-2    | MAC mode. 64-bit bidirectional mode |
| GPIO [1,2,3]    |                                     |
| GPIO [0,1,2,3]  | 32-Bit unidirectional mode          |



# **Port Specific Utilities**

Utilities for the RadiSys ENP-3510 are located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS

The following port specific utilities are included:

dmppci peeks PCI device information

pciv displays board PCI bus information

pflash programs onboard Flash

setpci pokes PCI device settings

#### **SYNTAX**

#### **OPTIONS**

- ?

Display help.

#### **DESCRIPTION**

dmppci displays PCI configuration information that is not normally available by other means, except programming, using the PCI library.

#### **EXAMPLE**

#### pciv



#### **SYNTAX**

pciv [<opts>]

#### **OPTIONS**

Display help. -?

Display base address information and size. -a

Display PCI routing information. -r

#### DESCRIPTION

The pciv utility allows visual indication of the status of the PCIbus.

#### **EXAMPLES**

When using the pciv command with a RadiSys ENP-3510, the following information is displayed:

```
$ pciv -a
BUS:DV:FU VID DID CMD STAT CLASS RV CS IL IP
______
000:00:00 8086 1200 0017 2200 0b4001 00 00 6e 0e
(NC) [32-bit] base_addr[0] = 0x40000008 PCI/MEM 0x60000008 Size = 0x00100000
(C) [32-bit] base_addr[1] = 0x50000001 PCI/IO 0x54000000 Size = 0x00000080
(NC) [32-bit] base_addr[2] = 0xc0000008 PCI/MEM 0xe0000008 Size = 0x02000000
IXP1200 Processor [S]
BUS:DV:FU VID DID CMD STAT CLASS RV CS IL IP
______
000:05:00 11ad 0002 0007 0280 020000 20 00 6e 01
(C) [32-bit] base_addr[0] = 0x54000001 PCI/IO 0x54000000 Size = 0x00000100
(C) [32-bit] base_addr[1] = 0x7ffffff00 PCI/MEM 0x7ffffff00 Size = 0x00000100
Network Controller [S]
```

The pciv command in the previous example reports configuration information related to specific hardware attached to the system.

#### DETAIL OF BASIC VIEW:

BUS : Bus Number DEV : Device Number : Vendor ID VID : Device ID DID CLASS : Class Code RV : Revision ID : Interrupt Line TT. ΙP : Interrupt Pin : Single function device [S]

[S] : Single function device[M] : Multiple function device

When the -a option is used, address information is displayed along with the size of the device blocks in use.

The fields in the previous example are, from left to right, as follows:

- Prefetchable
- Memory Type
- Address Fields
- Actual Value Stored
- Type of Access
- Translated Access Address Used (shown on second line)
- Size of Block (shown on second line)

When the -r option is used, PCI-specific information related to PCI interrupt routing is displayed. If an ISA BRIDGE controller is found in the system, the routing information is used. The use of ISA devices and PCI devices in the same system requires interrupts to be routed either to ISA or PCI devices. Since ISA devices employ edge-triggered interrupts and PCI devices use level interrupts, the EDGE/LEVEL control information is also displayed. If an interrupt is shown as LEVEL with a PCI route associated with it, no ISA card can use that interrupt. This command also shows the system interrupt mask from the interrupt controller.





## **Note**

ISA and PCI interrupts cannot be shared.

### **Program Strata Flash**

### pflash

## **Syntax**

pflash [options]

### **Options**

| -f[=]filename | input filename                                                                    |
|---------------|-----------------------------------------------------------------------------------|
| -eu           | erase used space only (default)                                                   |
| -ew           | erase whole Flash                                                                 |
| -ne           | do not erase Flash                                                                |
| -r            | program resident Flash (default)                                                  |
| -p0           | program PCMCIA slot 0                                                             |
| -p1           | program PCMCIA slot 1                                                             |
| -ncis         | do not emit cis for PCMCIA Flash cards                                            |
| -b[=]addr     | specify base address of Flash (hex) for part identification (replaces -r,-p0,-p1) |
| -s[=]addr     | specify write/erase address of Flash (hex) defaults to base address)              |
| -u            | leave Flash unlocked                                                              |
| -i            | print out information on Flash                                                    |
| -nv           | do not verify erase or write                                                      |
| -q            | no progress indicator                                                             |
|               |                                                                                   |

## **Description**

The pflash utility allows the programming of Intel Strata Flash parts. The primary use will be in the burning of the OS-9 ROM image into the on-board Flash parts. This allows for booting using the Ir/bo booters.



### setpci Set PCI Value

#### **SYNTAX**

setpci <bus> <dev> <func> <offset> <size{bwd}>
<value>

#### **OPTIONS**

-? Display help.

#### DESCRIPTION

The setpci utility sets PCI configuration information that is not normally available by other means, other than programming with the PCI library. The setpci utility may also be used to read a single location in PCI space. The following parameters are included:

<br/><bus> = PCI Bus Number 0..255

<dev> = PCI Device Number 0..32

<func> = PCI Function Number 0..7

<offset> = Offset value (i.e. command register offset = 4)

<size> = Size b=byte w=word d=dword

<value> = The value to write in write mode. If no value is

included, the utility is in read mode.

#### **EXAMPLES**

```
$ setpci 0 7 0 0x10 d
PCI READ MODE
PCI Value.....0x7feff000 (dword) READ
PCI Bus.....0x00
PCI Device.....0x07
PCI Function....0x00
PCI Offset....0x0010
$ setpci 0 7 0 0x10 d 0x1234500
PCI WRITE MODE
PCI Value.....0x01234500 (dword) WRITE
PCI Bus.....0x00
PCI Device.....0x07
PCI Function....0x00
PCI Offset....0x0010
$ setpci 0 7 0 0x10 d
PCI READ MODE
PCI Value.....0x01234000 (dword) READ
PCI Bus.....0x00
PCI Device.....0x07
PCI Function....0x00
PCI Offset....0x0010
```



## **Intel Work Bench Daemons**

The Intel<sup>®</sup> Developer Workbench daemons for the RadiSys ENP-3510 are located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS

The following daemons allow the Intel<sup>®</sup> Developer Workbench to interact with the RadiSys ENP-3510:

ixp\_engine System state deamon used to setup an

OS-9 to ixp\_serv interrupt interface.

ixp\_serv User state thread-based deamon that

communicates with the IXP1200 Developer Workbench to provide microcode load and debug support.



#### Note

Non-CSL versions of the daemons are located in the following directory:

mwos\os9000\ARMV4\PORTS\IXP1200\CMDS\NOCSL

## **Dependencies**



#### **Note**

There are incompatibilities between version 1.0 and 1.2 of the Intel<sup>®</sup> Developer Workbench. To deal with these incompatibilities a 1.0 version compatible daemon, <code>ixp\_serv1\_0</code>, is included. It is used in the same manner as <code>ixp\_serv</code> but works with version 1.0 of the Intel<sup>®</sup> Developer Workbench.

The <code>ixp\_serv</code> and <code>ixp\_engine</code> daemons provide communication between the Windows host and the target system via RPC over an Ethernet interface. To use the daemons you must perform minimal configuration on both the RadiSys ENP-3510 and on the Windows host system.

On the RadiSys ENP-3510 your boot file (os9kboot) must include a properly configured Ethernet interface.



#### For More Information

See the Creating the ROM Image section in Chapter 1.

At boot time, ensure that the network interface is running, along with the RPC portmapper service. The example in this section shows one variation of daemon startup.

From the Windows host system, you must start the Intel<sup>®</sup> Developer Workbench daemons. After loading a project, set it to the hardware option. Choose Ethernet as your means of communication and set the IP address of the RadiSys ENP-3510.



#### For More Information

See Appendix B: Running OS-9 and the Intel® Developer Workbench for more information.



#### uclo

#### **Load Microcode Object File**

**SYNTAX** 

uclo [<options>] [<microcode object files>]

**OPTIONS** 

-? Display help.

#### **DESCRIPTION**

The uclo utility loads a microcode object file into the IXP1200 Network Processor's microengines. The microcode object file must be in UOF format. (See the *Radisys Network Processor Development Tool User's Guide* for more information about generating and using UOF files.) The uclo utility causes the microengines to be initialized, but it does not start the IXP1200 Network Processor's microengines; this must be done by an application, driver, or other StrongARM code.

## **Example Daemon Start Up**

```
OS-9 Bootstrap for the ARM (Edition 64)
Now trying to Override autobooters.
Press the spacebar for a booter menu
Now trying to Copy embedded OS-9000 to RAM and boot.
Now searching memory ($00040000 - $001fffff) for an OS-9
Kernel...
An OS-9 kernel was found at $00040000
A valid OS-9 bootfile was found.
$ mbinstall
$ ipstart
$ portmap &
+3
$ ixp_engine &
+5
$ ixp_serv &
+6
$
```



# Appendix A: Board Specific Modules

This chapter describes the modules specifically written for the target board. It includes the following sections:

- Low-Level System Modules
- High-Level System Modules
- Common System Modules List







# **Low-Level System Modules**

The following low-level system modules are tailored specifically for the RadiSys ENP-3510. The functionality of many of these modules can be altered through changes to the configuration data module (cnfgdata). These modules are located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/ROM

armtimr Provides low-level timer services via

time base register.

cnfgdata Contains the low-level configuration

data.

cnfgfunc Provides access services to the

cnfgdata data.

commonfg Inits communication port defined in

cnfgdata.

conscnfg Inits console port defined in cnfgdata.

ioixp1200 Provides low-level serial services via the

IXP1200 serial unit.

11pro100 Provides low-level Ethernet services via

Intel 825xx PCI cards.

portmenu Inits booters defined in the cnfgdata.

romcore Provides board-specific initialization

code.

usedebug Initializes low-level debug interface to

RomBug, SNDP, or none.

initext Initializes PCI bus devices.

ioixp1200 Provides low level serial access to the

1200's UART.



# **High-Level System Modules**

The following OS-9 system modules are tailored specifically for the RadiSys ENP-3510. Unless otherwise specified, each module is located in a file of the same name in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS

## **CPU Support Modules**

These files are located in the following directory:

MWOS/OS9000/ARMV4/CMDS/BOOTOBJS

kernel Provides all basic services for the OS-9

system.

cache Provides cache control for the CPU

cache hardware. The cache module is

in the file cach1100.

fpu Provides software emulation for floating

point instructions.

System Security Module—provides

support for the Memory Management

Unit (MMU) on the CPU.

vectors Provides interrupt service entry and exit

code. The vectors module is found in

the file vect110.





## **System Configuration Module**

The system configuration modules are located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/INITS

dd Descriptor module with high level system

initialization information.

nodisk Descriptor module with high level system

initialization information, but used in a

diskless system.

configurer Descriptor module with high level system

(generated by the Wizard)

## **Interrupt Controller Support**

The interrupt controller support module provides an extension to the vectors module by mapping the single interrupt generated by an interrupt controller into a range of pseudo vectors. The pseudo vectors are recognized by OS-9 as extensions to the base CPU exception vectors. See the **GPIO Usage** section for more information.

irgixp1200 P2module that provides interrupt

acknowledge and dispatching support for the SA1200's pic (vector range

0x40-0x7d).

### **Real Time Clock**

rtcixp1200 Driver that provides OS-9 access to the

SA1200's on-board real time clock.



### **Ticker**

tkarm Driver that provides the system ticker

based on the ENP-3510's PCI timer.

hcsub Subroutine module that provides a high

speed timer interface used by the

HawkEye Profiler

## **Generic I/O Support Modules (File Managers)**

The generic I/O support modules are located in the following directory:

MWOS/OS9000/ARMV4/CMDS/BOOTOBJS

ioman Provides generic I/O support for all I/O

device types.

scf Provides generic character device

management functions.

rbf Provides generic block device

management functions for the OS-9

format.

pcf Provides generic block device

management functions for MS-DOS FAT

format.

spf Provides generic protocol device

management function support.

pipeman Provides a memory FIFO buffer for

communication.





## **Pipe Descriptor**

The pipe descriptor is located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/DESC

pipe Pipeman descriptor that provides a

RAM-based FIFO, which can be used for

process communication.

## **RAM Disk Support**

The pipe descriptor is located in the following directory:

MWOS/OS9000/ARMV4/CMDS/BOOTOBJS/

ram RBF driver that provides a RAM-based

virtual block device

## **RAM Descriptors**

The RAM descriptors are located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/DESC/RAM

r0 RBF descriptor that provides access to a

RAM disk.

r0.dd RBF descriptor that provides access to a

ram disk-with module name dd (for use

as the default device).

r1 RBF descriptor that provides access to a

4Meg RAM disk for Flash burning.

### **Serial and Console Devices**

scixp1200 SCF driver that provides serial support

the SA1200's internal UART.



## **Descriptors for use with sc1100**

term1/t1 Descriptor modules for use with

scixp1200

ENP-3510 Board header: J20

Default Baud Rate: 38400

Default Parity: None

Default Data Bits: 8

Default Handshake: XON/XOFF

scllio SCF driver that provides serial support

via the polled low-level serial driver.

## Descriptors for use with scllio

The scllio descriptors are located in the following directory:

mwos\os9000\ARMV4\PORTS\IXP1200\CMDS\BOOTOBJS\DESC\
SCLLIO

vcons/term Descriptor modules for use with scllio

in conjunction with a low-level serial driver. Port configuration and set up follows that which is configured in cnfgdata for the console port. It is possible for scllio to communicate with a true low-level serial device driver like iol100, or with an emulated serial

interface provided by iovcons.



## **For More Information**

See the **OS-9 Porting Guide** and the **OS-9 Device Descriptor and Configuration Module Reference** for more information.





## **SPF Device Support**

### **PCI Support for NE2000 Compatibility**

The NE2000 support module is located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF

spne2000 SPF driver to support PCI NE2000

Ethernet cards.

The following cards are supported: RealTek RTL-8029, Winbond 89C940, Winbond w89C940, Compex RL2000, KTI ET32P2, NetVin NV500SC, Via 82C926, SureCom NE34, Holtek HT80232, Holtek HT80229.

### spne2000 Descriptors

This descriptor file is located in the following directory:
MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF

spne0 SPF descriptor module for use with PCI.

## **PCI Support for 3COM Ethernet cards**

The 3COM support module is located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF

spe509 SPF driver to support ethernet for a

3COM PCI cards.

The following cards are supported: 5900, 9001, 3C900-TPO, 3C905-TX, 3C905-T4, 3CSOHO100-TX, 3C905B-TX,3C900B-TPO 3C900B-CMB, 9058, 9006, 900A, 905A, 9200, 9800, 9805

### spe509 Descriptors

These descriptor files are located in the following directory: MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF



| spe30 | SPF descriptor module for use with default PCI slot 0. |
|-------|--------------------------------------------------------|
| spe31 | SPF descriptor module for use with default PCI slot 1. |
| spe32 | SPF descriptor module for use with default PCI slot 2. |
| spe33 | SPF descriptor module for use with default PCI slot 3. |

#### **PCI Support for Intel Ethernet Pro cards**

The Intel Ethernet Pro support module is located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF

sppro100 SPF driver to support ethernet for a Intel

Ethernet Pro PCI cards.

The following cards are supported: 82557, 82559ER, 1029, 1030

#### sppro100 Descriptors

These descriptor files are located in the following directory: MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF

| MWOS/OS9000/ARMV4/PORIS/IAPI200/CMDS/BOOIOBUS/SPF |                                                        |
|---------------------------------------------------|--------------------------------------------------------|
| sppr0                                             | SPF descriptor module for use with default PCI slot 0. |
| sppr1                                             | SPF descriptor module for use with default PCI slot 1. |
| sppr2                                             | SPF descriptor module for use with default PCI slot 2. |
| sppr3                                             | SPF descriptor module for use with default PCI slot 3. |





#### **PCI Support for DEC 211xx Ethernet cards**

The DEC support module is located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF

sp21140 SPF driver to support ethernet for a Intel

Ethernet PRO PCI cards.

decv sp21140 utility that shows the state of

the Ethernet chip

The following cards are supported: DEC21143, DEC21140, DEC2104, Netgear FA310.

#### sp21140 Descriptors

These descriptor files are located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF

spde0 SPF descriptor module for use with

default PCI slot 0.

spde1 SPF descriptor module for use with

default PCI slot 1.

spde2 SPF descriptor module for use with

default PCI slot 2.

spde3 SPF descriptor module for use with

default PCI slot 3.

#### PCI Support for National DP83815 Ethernet Card

The National DP83815 support module is located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF

spfa311 SPF driver to support Ethernet for

Netgear FA311/312 83815 clones.



#### spfa311 Descriptors

These descriptor files are located in the following directory: MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF

spfa0 SPF descriptor module for use with

default PCI slot 0.

spfa1 SPF descriptor module for use with

default PCI slot 1.

spfa2 SPF descriptor module for use with

default PCI slot 2.

spfa3 SPF descriptor module for use with

default PCI slot 3.

#### **Network Configuration Modules**

These files are located in the following directory:

MWOS/OS9000/ARMV4/PORTS/IXP1200/CMDS/BOOTOBJS/SPF

inetdb

inetdb2

rpcdb





# **Common System Modules List**

The following low-level system modules provide generic services for OS9000 Modular ROM. They are located in the following directory:

MWOS/OS9000/ARMV4/CMDS/BOOTOBJS/ROM

bootsys Provides booter registration services.

console Provides console services.

dbgentry Inits debugger entry point for system

use.

dbgserve Provides debugger services.

exception Provides low-level exception services.

flshcach Provides low-level cache management

services.

hlproto Provides user level code access to

protoman.

11bootp Provides bootp services.

11ip Provides low-level IP services.

11slip Provides low-level SLIP services.

11tcp Provides low-level TCP services.

11udp Provides low-level UDP services.

11kermit Provides a booter that uses kermit

protocol.

notify Provides state change information for

use with LL and HL drivers.

override Provides a booter which allows choice

between menu and auto booters.

parser Provides argument parsing services.

pcman Provides a booter that reads MS-DOS

file system.



protoman Provides a protocol management

module.

restart Provides a booter that causes a soft

reboot of system.

romboot Provides a booter that allows booting

from ROM.

rombreak Provides a booter that calls the installed

debugger.

rombug Provides a low-level system debugger.

sndp Provides low-level system debug

protocol.

srecord Provides a booter that accepts

S-Records.

swtimer Provides timer services via software

loops.



#### For More Information

For a complete list of OS-9 modules common to all boards, see the *OS-9 Device Descriptor and Configuration Module Reference* manual.





# Appendix B: Running OS-9 and the Intel<sup>®</sup> Developer Workbench

This appendix provides a brief overview of using the Intel<sup>®</sup> Developer Workbench with an OS-9 system. It includes the following sections:

- Overview
- Intel Developer Workbench





#### **Overview**

The OS-9 ROM image provides an interface with the Intel Core Software Library. This enables loading and debugging of microcode to the Intel<sup>®</sup> Developer Workbench in a simulated environment or directly on the hardware. The simulated environment has more features than the hardware version and is more appropriate for detailed debugging.

The standard OS-9 image also contains the SPF daemons for Hawk debugging on the StrongARM core, the daemons for using the profiler, and most standard OS-9 utilities.



# Intel Developer Workbench

All RadiSys ENP-3510 Embedded Network Processor boards ship with the Intel® Developer Workbench.



#### For More Information

The Intel Developer Workbench, which was shipped with your hardware, is also available on CD from the Intel<sup>®</sup> Literature Center at the following URL:

http://apps.intel.com/scripts-order/
viewBasket.asp?Bundle=Bundle&site=developer

You can also order by phone at 800-548-4725, 7am to 7pm CST. Please ask for part number CDIXP12DE11. Outside U.S. please allow 2-3 weeks for delivery.

The Enhanced OS-9 for IXP1200 board-level solution provides the necessary daemons to enable integration of the Intel and OS-9 environments. The following procedures describe how to configure the environment and run a sample microcode project.



#### Note

The following procedures assume that you have completed the steps described in **Chapter 1**.



### **System Configuration**

Step 1. Install version 1.2 of the Intel<sup>®</sup> Developer Workbench. Installation requires a key, available from the Intel website at the following URL:

http://developer.intel.com/design/network/products/npfamily/ixp1200.htm

Step 2. Run the sample project.

In the Hyperterminal window, the following messages display as the RadiSys ENP-3510 is booted up:

```
OS-9 Bootstrap for the ARM (Edition 64)

Now trying to Override autobooters.

Press the spacebar for a booter menu

Now trying to Copy embedded OS-9000 to RAM and boot.

Now searching memory ($00040000 - $001fffff) for an OS-9 Kernel...

An OS-9 kernel was found at $00040000

A valid OS-9 bootfile was found.
```

Step 3. Start networking by typing the following command at the OS-9 prompt: ipstart &. The following messages are displayed:

```
#3
$
SPPRO100: Intel PCI EtherExpress Pro100 - PCI Device ID 0x1229
SPPRO100: PCI device located @ BUS:DEV [0000:0007]
SPPRO100: PCI I/O address 0x54000000
SPPRO100: PCI DMA translation address 0x000000000
SPPRO100: Transmit rings 0x40 Receive rings 0x40
SPPRO100: Connection Type [INF_EXT] - Duplex mode [INF_AUTO_DUPLEX]
SPPRO100: Processor cache line flushing enabled
SPPRO100: Board assembly = 721383-10
SPPRO100: Physical connectors present: RJ45
SPPRO100: Primary interface chip i82555
SPPRO100: MII - PHY # 0x01
SPPRO100: Receiver lock-up workaround not required. [0x0203 0x0200 0x07B3]
SPPRO100: Memory allocated @ 0xC0FE68A0 - Size 0x00019760 - Color 0x00000002
```

- Step 4. Start RPC by typing the following command at the OS-9 prompt:
- Step 5. Start the first Intel<sup>®</sup> Developer Workbench daemon by typing the following command at the OS-9 prompt: ixp\_engine &.



- Step 6. Start the second Intel<sup>®</sup> Developer Workbench daemon by typing the following command at the OS-9 prompt: ixp\_serv &.
- Step 7. Configure the Ethernet settings and check the network settings by typing the following two commands at the OS-9 prompt:

```
$ ifconfig enet0 172.16.1.236
$ netstat -in
Name Mtu Network
                 Address
                                   Ipkts Ierrs Opkts Oerrs Coll
lo0 1536 <Link>
    1536 127
                 127.0.0.1
                                     4
100
                                           0
                                                  4
                                                      0
                                                           0
enet0 1500 <Link>
                 00.02.B3.07.12.01
                                   267
                                         0
                                                  0
                                                      0
                                                           0
enet0 1500 172.16
                 172.16.1.236
                                    267
                                                           0
```



#### **Note**

The IP address used above is an example only. You must get your specific network information from your network administrator.

### **Running the Sample Project**

The following example requires the Hawk and Profiler daemons to be running on the RadiSys ENP-3510.

Step 1. Start the Hawk daemon by typing the following command at the OS-9 prompt (in the Hyperterminal window):

```
spfndpd &
```

Step 2. Start Profiler daemon by typing the following command at the OS-9 prompt:

```
spfnppd &
```

Step 3. From the Windows host system, select Start -> Programs -> Intel IXP1200 -> Developer Workbench. The Intel<sup>®</sup> Developer Workbench opens in the foreground.



- Step 4. From the Intel<sup>®</sup> Developer Workbench select File -> Open Project. The standard Windows file search box is displayed.
- Step 5. Browse to and open the following file:

IXP1200\Microcode\examples\bit\_swiz.dwp

The project is opened and the file tree is visible on the right (source macro script).

- Step 6. Select Debug -> Hardware. A check box goes to the hardware menu.
- Step 7. Select Hardware -> Options. The **Hardware Options** screen is displayed.
- Step 8. Click on **Connect via Ethernet** and enter your target IP address.
- Step 9. Click OK.
- Step 10. Click on the **Bug** picture on the right side of the screen. The Intel<sup>®</sup> Developer Workbench screen changes, and the MicroEngine window opens at the bottom. You may have to click on **spool**.
- Step 11. Expand the MicroEngine 0 by clicking +. Thread 0-0 through Thread 3-0 will be exposed.
- Step 12. Click the green traffic sign to load and start executing the microcode. The arrow in the MicroEngine window will advance as code runs on different engines.

## Intel® Developer Workbench Interface Notes

- The button that resembles steps (labeled HOP) will single step after stopping.
- Double clicking on code can bring it to the foreground, and arrows will move through the code when it is being executed.
- Right clicking and holding brings up a breakpoint window. This can also be done from the debugger pull-down menu.
- This procedure can be run in the SIMULATOR by not choosing the two hardware options WB4/WB5. This gives you a practice run.

# **Product Discrepancy Report**

| Io: Microware Customer Supp | port   |
|-----------------------------|--------|
| FAX: 515-224-1352           |        |
| From:                       |        |
| Company:                    |        |
| Phone:                      |        |
|                             | Email: |
| Product Name:               |        |
| Description of Problem:     |        |
|                             |        |
|                             |        |
|                             |        |
|                             |        |
|                             |        |
|                             |        |
|                             |        |
|                             |        |
|                             |        |
|                             |        |
| Host Platform               |        |
| Target Platform             |        |

