

# Allocating Address Space in a 32-bit Processor

## Summary

This application note provides detailed information on mapping memory and peripherals into a 32-bit processor's address space.

Application Note AP0149 (v2.0) February 27, 2008

An FPGA design incorporating a 32-bit processor will typically involve the connection of slave memory and peripheral devices – to the processor's External Memory and Peripheral I/O interfaces respectively. This is physical connection, the wiring of the devices to the processor. At this point, the processor – and more importantly the embedded code therein – is 'unaware' of the existence of such devices, with respect to its address space. These physical slave devices must now be mapped into specific locations within that address space.

The 'memory map', as it is often called, is essentially the bridge between the hardware and software projects – the hardware team allocating each of the various memory and peripheral devices their own chunk of the processor's address space, the software team then writing their code to access the memory and peripherals at the given locations.

# **Address Space Mapping - Overview**

Processor address space can be configured from within the FPGA project (both Memory and Peripheral I/O) or the Embedded Software project (Memory only). In both cases, mapping can be achieved quickly by importing slave device information directly from the relevant schematic sheet. Once imported, the mapping of devices can be 'hand-crafted' as required. With respect to the Embedded Software project, you can also opt to automatically import dedicated memory mapping definitions directly from the FPGA project upon compilation.

You can also generate .asm and/or .h files for the Embedded Software project, upon FPGA project compilation, providing a means to quickly and efficiently address devices from within the embedded source code.

Figure 1 summarizes the key elements to defining processor address space in terms of memory and peripheral I/O and where such elements can be defined.



Figure 1. Configuring Processor Memory and Peripheral I/O.

## A Word on Mapping Physical Memory...

When configuring processor memory, the physical memory devices are mapped into the processor's address space – in the Internal and External Memory ranges – but can also be further broken down into separate logical spaces (or sections) for reference by and within the embedded source code. Figure 2 illustrates this concept of memory space allocation.



Figure 2. Allocating processor and physical device memory spaces.

From left to right, Figure 2 shows:

- The predefined memory architecture of the 32-bit processor. The 4GB linear address space divided between Internal Memory (16MB), External Memory and Peripheral I/O space (16MB). This architecture is static (i.e. cannot be changed by the user)
- Physical memory spaces. In the example of Figure 2, there are four physical memory spaces Internal Memory, Daughter Board SRAM, NanoBoard SRAM and FPGA BRAM. The dotted lines indicate where in the processor's address space these physical devices are mapped, and the sizing of each
- Logical memory spaces, showing the mapping of specific sections within the embedded code to the physical device memory.

## **Mapping Physical Memory from within the FPGA Project**

Typically, the required physical memory devices will be added to the design and wired to the processor's External Memory interface accordingly, before mapping is performed. To illustrate, consider the circuitry of Figure 3.



Figure 3. Connection of physical memory devices to the 32-bit processor.

Here, physical memory on the NanoBoard and Daughter Board, as well as Block RAM within the target FPGA device, is connected to the processor's External Memory interface. The processor in this case is a TSK3000A, but could just as easily be swapped for any of the other 32-bit processors available in Altium Designer. Connection to the interface is made through use of a configurable Wishbone Interconnect device (WB\_INTERCON).

For more information on connecting physical memory devices to a processor, refer to the application note *Connecting Memory and Peripheral Devices to a 32-bit Processor.* 

From within the FPGA project, mapping of physical memory into the processor's address space is performed using the *Configure Processor Memory* dialog (Figure 4). Access this dialog by right-clicking on the symbol for the processor (in the schematic) and choosing **Configure Processor Memory** from the context menu that appears. Alternatively, use the **Configure Processor Memory** button available from the *Component Properties* dialog for the processor.

#### Allocating Address Space in a 32-bit Processor

| Processor Architecture       Defined Memory Devices<br>This is the processor view of the memory         0x7777_7777       Processor I/O Space<br>[IP or<br>of the processor       0x7770_10         0x7770_0000       0 the processor       0x7770_10         0x7777_7777       Processor I/O Space<br>[IP or<br>of the processor       0x7770_10         0x7770_0000       0 the processor       0x7770_10         0x7000_0000       xxem [Volatile RAM]       0x000_10         0x0000_0000       0x0000_0000       0x0000_000         0x0000_0000       0x0000_0000       0x0000_000         0x0000_0000       0x0000_000       0x0000_000         0x0000_0000       0x0000_                                   | Configure Processor Memory |                                                                                                          |        |                                                                        |             |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------|-------------|--|
| OxFFFF_PFF         OxFFFF_COUNT         OxFFFFF_COUNT         OxFFFFF_COUNT         OxFFFFF_COUNT         OxFFFFF_COUNT         OxFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                            | Processor Architecture                                                                                   |        | Defined Memory Devices<br>This is the processor's view of the memories |             |  |
| 0x2777_7777     Processor 1/0 Space<br>0 of the processor     0x7700_000     0x7700_000     0x7700_000       0x7700_0000     of the processor     0x7700_000     0x7700_000       0x7000_0000     External-Memory Space     xcom (Volatile RAM)     0x0000_0000       0x0000_0000     0x0000_0000     0x0000_0000     0x0000_0000       Name     0x0000_0000     0x0000_0000     0x0000_0000       Name     0x100000     0x0000_0000     0x0000_0000       0x0000_0000     512k     Volatile RAM     0x0000_0000       0x0000_0000     512k     Volatile RAM     0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                            | OxFFFF_FFFF                                                                                              |        | OxFFFF_FFF                                                             |             |  |
| 0x7170_0000         0x700_1         0x700_1           0x7100_0000         External Memory Space         xxam (Volatile RAM)         0x0107_1           0x0000_0000         0x0000_1000         0x0000_1000         0x0000_1000           0x0000_0000         0x0000_000         0x0000_1000         0x0000_1000           0x0000_0000         0x0000_000         0x0000_1000         0x0000_1000           0x0000_000         0x0000_1000         0x0000_1000         0x0000_1000           0x0000_000         0x0000_1000         0x0000_1000         0x0000_1000           0x0000_1000         0x0000_1000         0x0000_1000         0x0000_1000           0x0000_1000         0x0000_1000         0x0000_1000         0x0000_1000           0x0000_1000         0x0000_1000         0x0000_1000         0x0000_1000           0x000_10000         0x000 | OxFFFF_FFFF                | Processor I/O Space<br>IO Port<br>of the processor                                                       |        | Reserved for Processor I/O Space<br>IO Port<br>of the processor        | OxFFFF_FFFF |  |
| 0x0100_0000         External-Memory Space         xram [Volatile RAM]         0x0100_0           0x0000_0000         0x0000_0000         0x0000_0000         0x0000_0000           0x0000_0000         0x0000_0000         0x0000_000         0x0000_000           0x0000_0000         0x0000_0000         0x0000_000         0x0000_000           0x0000_0000         0x00000_000         0x0000_000         0x0000_000           Name         Address         / Size         Type           wrom         0         64k         ROM         Valatie RAM           Generate following files into the subproject[s] at FPBA Project complation                                                                                                                    | OXFEER FREE                |                                                                                                          | -      |                                                                        | 027700_0000 |  |
| 0x0100_0000     0x0007_1       0x000F_0000     0x0000_0       0x0000_0000     0x0000_0000       0x0000_0000     0x0000_000       0x0000_0000     512k       Volatile RAM     RDM       Generate following files into the subproject(s) at FPGA Project compilation         hardware.asm (Assembly File)       hardware.h (C Header File)                                                                                                                                                                                                                                                                                                        | -                          | External-Memory Space                                                                                    |        |                                                                        |             |  |
| 0x00FF_FFF     Internal-Memory<br>Where the<br>boot code resides     0x0000_10000     0x0000_10000       0x0000_0000     0x0000_0000     0x0000_0000       Name     Address     / Size     Type       xrom     0     64k     ROM       yram     0x1000000     512k     Volatile RAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0×0100 0000                |                                                                                                          |        | xram (Volatile RAM)                                                    | 0x0107_FFFF |  |
| Ox0000_0000         Ox0000_0000           Name         Address         Size         Type           xrom         0         64k         RDM           xram         0x1000000         512k         Volatile RAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x000FF_FFFF               | Internal-Memory<br>Where the<br>boot code resides                                                        |        | xrom (ROM)                                                             | 0x0000_FFFF |  |
| Name     Address     / Size     Type       xrom     0     64k     ROM       wam     0x1000000     512k     Volatile RAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                            | 0x0000_0000                                                                                              |        | 0x0000_0000                                                            |             |  |
| Some 0 64k RDM     Xram 0x1000000 512k Volatile RAM  Generate following files into the subproject(s) at FPGA Project compilation     hardware.asm (Assembly File) hardware.h (C Header File)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Name                       | Address                                                                                                  | ∠ Size | Тире                                                                   |             |  |
| xram 0x1000000 512k Volatile RAM Generate following files into the subproject(s) at FPGA Project compilation hardware.asm (Assembly File) hardware.h (C Header File)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | xrom                       | 0                                                                                                        | 64k    | ROM                                                                    |             |  |
| Generate following files into the subproject(s) at FPGA Project compilation           hardware.asm (Assembly File)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | xram                       | 0x1000000                                                                                                | 512k   | Volatile RAM                                                           |             |  |
| Catta Dafash Umant Fore Selamatian Continue Baisharah                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Generate following         | g files into the subproject(s) at FPGA Project compilation<br>(Assembly File) hardware h (C Header File) |        |                                                                        |             |  |

Figure 4. Configuring processor memory from within the FPGA project

The dialog is divided into two regions. The top region provides a visual summary of the memory devices that are currently defined and mapped into the processor's address space – i.e. the processor's 'view' of the actual physical memories in the design. The bottom region of the dialog provides a tabular listing of each of these defined memory devices.

Default memory devices are initially defined and mapped. These will vary depending on the processor type being configured. For the TSK3000A in our example circuit, the following devices are mapped by default:

- **xrom** this ROM device is mapped into the processor's Internal Memory address range, in order to cater for storage of the processor's embedded code. Starting at address 0000\_0000h, it is sized to give 64KB of Internal Memory
- **xram** this RAM device is mapped into the processor's External Memory address range in order to cater for the storage of data. Starting at address 0100\_0000h, it is sized to give 512KB of external memory.

Bear in mind that these are default memory mappings – the actual physical devices may not yet exist in the design or, if they do, may not be identical in size.

Controls are also provided in the dialog for generating header files (Assembly or C) upon compilation of the FPGA project.

The dialog also provides a **Configure Peripherals** button – allowing you to quickly jump between memory and peripheral configuration dialogs. Note that when using this facility, you will be prompted to confirm whether you wish to save the configuration of the current dialog before proceeding to the other dialog.

# Importing Device Information from the FPGA Project Schematic

If you have connected your physical memory device(s) to the processor through a Wishbone Interconnect, then the simplest way to make these devices 'known' to the processor – and automatically have them mapped into the processor's address space – is to use the *Configure Processor Memory* dialog's Import from Schematic feature.

Launched by clicking on the **Import From Schematic** button, the feature essentially scans the FPGA design for configurable Wishbone Interconnect devices. All detected interconnect devices, along with the slave devices associated to them, are presented in the *Choose Wishbone Items* dialog (Figure 5).



Figure 5. Selecting memory devices to import into processor address space.

Prior to the dialog appearing, you will be given the choice of whether or not to delete any existing memory device definitions that have been added. If you have not yet configured the processor memory, or want to start over again from a 'blank canvas' as it were, then opting to delete here is the best course of action.

On the other hand, you may have already defined memories that you wish to keep. This can be the case when adding additional physical memory to an already well-established design. In this case, it is better to not to delete the existing definitions, but rather import just the addition(s).

Each slave memory device connected to an Interconnect is listed in the dialog, in terms of its identifier. This identifier is assigned as part of the slave device's definition when configuring the Interconnect. The dialog offers the ability to import selected devices or all devices associated to a given Interconnect, by clicking on the relevant entry in the **Import to Bus** column. Choose the physical memory devices you wish to import and click **OK**.

Importing will:

- Add memory device definitions where they currently do not exist. The identifier of an Interconnect slave device defined when configuring the Interconnect will be used to name the memory device definition.
- Update any existing memory device definitions, only if the identifier of the Interconnect slave device matches that of an existing memory device definition.
- Preserve exisiting memory device definitions whose identifiers do not match those of the Interconnect slave devices being imported leaving hand-crafted definitions untouched.

Update to/preservation of existing memory device definitions, will only be possible where you have opted to not delete the existing configuration before importing.

Only the internal memory defined for the processor and physical memory devices

connected to the processor via a Wishbone Interconnect device will be imported using the Import from Schematic feature. If a memory device is connected directly to the processor's External Memory interface (via the appropriately configured memory controller and any additional wiring), it will not be imported and mapped.

Figure 6 illustrates an example of this mapping based on the example schematic circuitry of Figure 3. The default memory definitions have been deleted prior to import.

| Configure Pro        | cessor Memory                                      |             |                                                                        | ? 🔀                        |
|----------------------|----------------------------------------------------|-------------|------------------------------------------------------------------------|----------------------------|
|                      | Processor Architecture                             |             | Defined Memory Devices<br>This is the processor's view of the memories |                            |
|                      | OxFFFF_FFFF                                        |             | OxFFFF_FFFF                                                            |                            |
| OxFFFF_FFFF          | Processor I/O Space<br>IO Port<br>of the processor |             | Reserved for Processor I/O Space<br>IO Port<br>of the processor        | OxFFFF_FFFF                |
| OxFEFF_FFFF          |                                                    |             |                                                                        |                            |
|                      | External-Memory Space                              |             | BRAM (Volatile RAM)<br>U_INTERCON_MEM                                  | 0x0140_0FFF                |
|                      |                                                    |             | NB_SRAM (Volatile RAM)<br>U_INTERCON_MEM                               | 0x0123_FFFF                |
| 0x0100 0000          |                                                    |             | DB_SRAM (Volatile RAM)<br>U_INTERCON_MEM                               | 0x0110_0000<br>0x0100_0000 |
| 0x00FF_FFFF          | Internal-Memory<br>Where the<br>boot code resides  |             | U_MCU1 (ROM)                                                           | 0x0000_1FFF                |
| 00000_00000          | 0x0000_0000                                        |             | 0x0000_0000                                                            |                            |
| Name                 | Address /                                          | Size        | Tupe Interrupts                                                        |                            |
| U MCU1               | 0                                                  | 8192        | BOM                                                                    |                            |
| DB SBAM              | 0x1000000                                          | 0x200000    | Volatile BAM                                                           |                            |
| NB SRAM              | 0x1200000                                          | 0x40000     | Volatile RAM                                                           |                            |
| BRAM                 | 0x1400000                                          | 0x1000      | Volatile RAM                                                           |                            |
|                      |                                                    |             |                                                                        |                            |
| Generate followin    | a files into the subproject(s) at FPGA Project c   | ompilation  |                                                                        |                            |
| 🔲 hardware.asm       | (Assembly File) 🔄 hardware.h (C Heade              | r File)     |                                                                        |                            |
| Set to <u>D</u> efau | t Import From Schematic Configure                  | Peripherals | <u></u> K                                                              | <u>C</u> ancel             |

Figure 6. Defining memory devices automatically by importing from the schematic.

If you do not wish to import any devices, simply click on the **Skip** button (in the *Choose Wishbone Items* dialog) – only the definition of the processor's internal memory will be imported.

## **Managing Memory Device Definitions**

Importing from the FPGA project schematic will define memories from the processor's perspective that are exactly in-line with the physical memory devices placed and wired-up on the schematic sheet. Once imported, you may well want to hand-craft how the processor really 'sees' these memories. For example, you may want to specify a single physical memory device in the design to be seen as several memory devices by the processor – essentially 'carving up' the address range of the true physical device into sub-ranges.

New memory device definitions may be added, or existing ones modified or deleted, using the available commands on the right-click menu for the *Configure Processor Memory* dialog. An existing memory device can also be modified with respect to its definition by double-clicking on its corresponding entry in the list section of the dialog, or by double-clicking on its 'block' in the graphical display. The associated *Processor Memory Definition* dialog will appear (Figure 7).

The dialog enables you to accurately define the memory device in terms of its size and base address -

| Processor Memory Definition                                                                                                                                                                                                                                                                                                  | ? 🛛                                                                                                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Physical Memory Device                                                                                                                                                                                                                                                                                                       | )                                                                                                                                                                                                                    |
| Name           DB_SRAM           The unique identifier of this memory device.           When the FPGA project is compiled these memory details will be passed to the embedded software project.           This identifier will also be used to uniquely identify the output HEX file.           Names cannot contain spaces. | Address Base<br>0x1000000<br>This is the processor's view of where the<br>memory appears in the address space.<br>The size can be specified as a decimal or hex<br>value.<br>Examples: 10000, 0x10000, 1k, 64k, 1M   |
| Type         Memory Type:       RAM · Volatile         Memory Type:       0 - Fastest         Choose the type and relative speed of the memory device.         The linker will use the relative speed settings of the different memories to try and optimize overall performance.                                            | Size<br>0x200000<br>This represents the amount of memory that is<br>available to the processor from this device.<br>The size can be specified as a decimal or hex<br>value.<br>Examples: 10000, 0x10000, 1k, 64k, 1M |
|                                                                                                                                                                                                                                                                                                                              | <u><u>O</u>K <u>C</u>ancel</u>                                                                                                                                                                                       |

Figure 7. Defining a mapped physical memory device.

specifying where in the processor's address space it is

to be mapped. You can specify these values using decimal or Hex notation (e.g. 10000, 0x10000, 1k, 64k, 1M).

The **Name** field allows you to define a unique identifier for the device. The identifier for each memory device will be used when generating header files for inclusion into the Embedded Software project (see the section *Generating Header Files for the Embedded Software Project*). The identifiers will also be used to uniquely identify the corresponding output HEX files.

The identifier used must not contain any spaces.

The **Type** region of the dialog allows you to set the type and relative speed of the memory device. The memory type can be either ROM or RAM (volatile or non-volatile). Six speed settings are available to choose from, ranging from 0 (fastest) to 5 (slowest). The Linker uses the speed settings for all defined memories in order to best optimize the overall performance and efficiency of the code.

How the processor's memory address space is allocated to the various physical memory devices in a design ultimately depends on the function of the physical memory device and individual design requirements. All but one physical memory device will be mapped into the processor's External Memory address range. The exception is the Dual port FPGA Block RAM used to implement the processor's internal memory. This will be mapped into the processor's Internal Memory address

The memory device definitions are stored as part of the processor component.

range. This will always be mapped starting at the base address of 0000\_0000h. The processor's Internal Memory address range is 16MB. The actual size of the physical RAM mapped into this range will be driven by how much physical BRAM is available in the target FPGA device. This is typically between 4KB and 1MB.

# Mapping Physical Memory from within the Embedded Project

From within the Embedded Software project, mapping of physical memory into the processor's address space is performed from the **Configure Memory** tab of the *Options for Embedded Project* dialog (Figure 8). Access this dialog by right-clicking on the project's entry in the *Projects* panel and choosing **Project Options** from the context menu that appears.

| Options for Emb     | edded Project TestInstructions.P                   | jEmb           |                     |                                                  |                        | ? 🛛         |
|---------------------|----------------------------------------------------|----------------|---------------------|--------------------------------------------------|------------------------|-------------|
| Compiler Options    | Files With Options Parameters Config               | gure Memory    | Sections/Reserved / | Areas                                            |                        |             |
|                     | Processor Architecture                             |                |                     | Defined Memory<br>This is the processor's view   | Devices                |             |
|                     | OxFFFF_FFFF                                        | 1              |                     | OxFFFF_FF                                        | FF                     |             |
| OxFFFF_FFFF         | Processor I/O Space<br>IO Port<br>of the processor |                |                     | Reserved for Process<br>IO Port<br>of the proces | or I/O Space           | OxFFFF_FFFF |
| OxFEFF_FFFF         |                                                    |                |                     |                                                  |                        |             |
|                     | External-Memory Space                              |                |                     | BRAM (Volatile<br>U_INTERCON_                    | RAM)<br>Mem            | 0x0140_0FFF |
|                     |                                                    |                |                     | NB_SRAM (Volat<br>U_INTERCON_                    | <b>ile RAM)</b><br>MEM | 0x0123_FFFF |
| 0x0100 0000         |                                                    |                |                     | DB_SRAM (Volat<br>U_INTERCON_                    | ile RAM)<br>_MEM       | 0×011F_FFFF |
| OxOOFF_FFFF         | Internal-Memory<br>Where the<br>boot code resides  |                |                     | U_MCU1 (R                                        | OM)                    | 0x0000_1FFF |
| 0x0000_0000         | 0×0000 0000                                        |                |                     | 0×0000_00                                        | 00                     | 0x0000_0000 |
|                     |                                                    |                |                     |                                                  |                        |             |
| Name                | Address                                            | Size           |                     | Туре                                             | Interrupts             |             |
| U_MCU1              | 0                                                  | 8192           | F                   | HUM                                              |                        |             |
| DB_SRAM             | 0x1000000                                          | 0x200000       | \                   | /olatile RAM                                     |                        |             |
| NB_SRAM             | Ux1200000                                          | 0x40000        | \                   | /olatile HAM                                     |                        |             |
| DNAM                | UX1400000                                          | UXIUUU         |                     | vulaule nAM                                      |                        |             |
| Import From S       | chematic Automatically import when o               | compiling FPG. | A project           |                                                  |                        |             |
| Set To Installation | n <u>D</u> efaults                                 |                |                     |                                                  | ОК                     | Cancel      |

Figure 8. Configuring processor memory from within the Embedded Software project

Controls for memory device definition are similar to those found in the *Configure Processor Memory* dialog when configuring memory within the FPGA project. Use the right-click menu to access commands for adding new memory definitions, or for editing/deleting existing definitions.

It is quite common for the Embedded software to be developed in parallel with the FPGA design and, with the two not linked, the Embedded Software Developer has no knowledge of the physical memory devices being placed by the FPGA Designer. Typically, the Embedded Software Developer will make an educated guess as to the memories available and continue to develop accordingly, and independently.

When the time comes to synchronize the two independently-developed projects – linking the Embedded project as a sub-project of the FPGA project – the Embedded Software Developer simply imports the memory definitions for the processor, from the FPGA design. This can be achieved in two ways:

- **Manually** by using the *Import From Schematic* button. The memory definitions stored with the processor component are imported directly from the FPGA design, provided that the design has been compiled.
- Automatically by enabling the Automatically import when compiling FPGA project option. When the FPGA project is
  compiled, the memory device definitions for the processor will automatically be passed to the linked embedded software
  project.

If you are manually defining memory device definitions in the **Configure Memory** tab of the *Options for Embedded Project* dialog, those definitions will be stored as part of the Embedded project. While the Auto-Import option is not enabled, the dialog will always use the project's stored definitions. When the Auto-Import option is enabled (and the Embedded and FPGA projects linked), these project-based definitions will be by-passed, in favor of those definitions stored as part of the processor component in the FPGA design.

## **Sections and Reserved Areas**

Once the view of the physical memory devices has been defined from the processor's perspective, it is then possible to further sub-divide these into logical sections. This allows the embedded software tools to place different parts of the software application:

- into different physical memory devices and
- into different locations within a single physical memory device.

These named "sections" can then be referenced from assembler and C source code, to enable code and data to be placed at certain memory locations. This allows for fine control over how the program is located or uses memory.

As well as defining areas in which to place code 'sections', you can also specify areas of memory that are off-limits to the Linker – reserved areas in which code cannot be placed (analogous to the use of keepouts from a physical board-level perspective).

Sections and reserved areas are defined and managed from the **Sections/Reserved Areas** tab of the *Options for Embedded Project* dialog (Figure 9). Access this dialog by right-clicking on the project's entry in the *Projects* panel and choosing **Project Options** from the context menu that appears. This tab can be also accessed directly from the *Component Properties* dialog for the processor, from within the FPGA design.

| tions for   | Embedde      | d Project        | TestInstru | ctions.PrjEr | nb           |        |           | ?         |
|-------------|--------------|------------------|------------|--------------|--------------|--------|-----------|-----------|
| Compiler Op | ptions Files | With Option      | s Paramete | rs Configure | Memory       | Sectio | ns/Reserv | red Areas |
| Туре        | Name         | Space            | Location   | △ Size       | Fill Bit P   | attern | Note      |           |
|             |              |                  |            |              |              |        |           |           |
|             |              |                  |            |              |              |        |           |           |
|             |              |                  |            |              |              |        |           |           |
|             |              |                  |            |              |              |        |           |           |
|             |              |                  |            |              |              |        |           |           |
| 644 G       | Section      | Add Bess         | arved Area | Edit         |              | lete   | 1         |           |
| Add         | Section      | Add <u>R</u> ese | erved Area | <u>E</u> dit | ) <u>D</u> e | lete   | )         |           |

Figure 9. Defining Sections and Reserved Areas as part of Embedded Project options.

Controls are provided, both in terms of buttons and a right-click menu, to add new Section and/or Reserved Area definitions, or edit/delete existing ones.

## Sections

Click the Add Section button within the Sections/Reserved Areas tab to access the Section dialog (Figure 10).

| Section                                                                                                                                                                                                                                                                                                                                                                                                      | ? 🛛                                                                                                                                                                                                                                                                                                                               |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Section Section Name NewSection This is a reference to the section defined in the source code. Sections can be used to create finer control over the way the program is located or uses memory. Example (C Code): To reference the .text section of a section definition #pragma section ''mysec'' <c code=""> #pragma endsection, use the name .text.mysec Example (ASM Code): To reference the section</c> | Location         Dx0         This is the processor's view of where the section appears in the address space. The size of the section is automatically allocated.         The location can be specified as a decimal, a hex value or a memory.         Examples: 10000, 0x10000, 1k, 64k, 1M, mem.memname         Fill Bit Pattern |
| Example (ASM Code): To reference the section<br>defined by .section .text.mysec, at(0x01000000)<br><asm code="">endsec, use the name<br/>.text.mysec</asm>                                                                                                                                                                                                                                                   | Used to initialize the empty spaces at the end of<br>the section as a result of MAU alignment.<br>If this section is located in ROM, leaving this<br>field empty fills the empty spaces with zeros.<br>If the section is in RAM, leaving this field empty<br>means the empty spaces are not initialized.<br>Example: 0xAA         |
| Notes                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                              | <u>D</u> K <u>C</u> ancel                                                                                                                                                                                                                                                                                                         |

Figure 10. Defining a section within processor address space.

Use the **Name** region of the dialog to reference the required section defined in the source code. For example, if the source code is written in assembly code (\*.asm) and the following section is defined:

```
.section.text.shiftcontrol, at(0x02000000)
```

```
.
Code Statements
```

.endsec

then the name specified in the Section dialog in order to reference this section definition would be .text.shiftcontrol.

The **Location** region allows you to specify where in the processor's address space the section is to be located. Simply enter a base address for the section – the size will be automatically allocated. You can specify the location using decimal or Hex notation (e.g. 10000, 0x10000, 1k, 64k, 1M). Alternatively, you can specify the location as a specific memory, in the format mem:memname.

The **Fill Bit Pattern** region allows you to specify a value to be used to initialize the empty spaces at the end of the section, as a result of MAU alignment. Leaving this field empty will:

- Fill the empty spaces with zeros if the section is located in ROM
- Leave the empty spaces uninitialized, if the section is located in RAM.

Use the Notes section to add any comments, such as the purpose for the section, when it was added, who it was added by, etc.

#### **Reserved Areas**

Click the Add Reserved Area button within the Sections/Reserved Areas tab to access the Reserved Area dialog (Figure 11).

| Reserved Area                                                                                                                                                                                                                                                                 | ? 🛛                                                                                                                                                                                                                                                                                 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved Area<br>Prevents an area from being used in the linking and<br>Location<br>0x0<br>This is the processor's view of where the area<br>is in the address space.<br>The location can be specified as a decimal or<br>hex value.<br>Examples: 10000, 0x10000, 1k, 64k, 1M | I locating process Size Ik This represents the amount of memory to be reserved. The size can be specified as a decimal or hex value. Examples: 10000, 0x10000, 1k, 64k, 1M Fill Bit Pattern Used to initialize the reserved area. Leave this field to initialize the reserved area. |
| Notes                                                                                                                                                                                                                                                                         | Example: UXAA                                                                                                                                                                                                                                                                       |

Figure 11. Defining a Reserved Area within processor address space.

The Location region allows you to specify where in the processor's address space the reserved area is to be located. Simply enter a base address for the area, using decimal or Hex notation (e.g. 10000, 0x10000, 1k, 64k, 1M).

The **Size** region of the dialog enables you to specify how much memory should be reserved using this area definition. Enter the value as required – again decimal or Hex notation can be used (e.g. 10000, 0x10000, 1k, 64k, 1M).

Use the Fill Bit Pattern region to specify a value with which to initialize the reserved area, if required.

Use the Notes section to add any comments, such as when the area was added, who it was added by, etc.

# **Configuring Processor Peripheral I/O**

Typically, the required peripheral devices will be added to the design and wired to the processor's Peripheral I/O interface accordingly, before mapping is performed. To illustrate, consider the circuitry of Figure 12.



Figure 12. Connection of peripheral I/O devices to the 32-bit processor.

Here, three configurable Wishbone port devices (configured with 8-, 16- and 32-bit data widths respectively) have been connected to a TSK3000A 32-bit processor. Connection to the processor's External Peripheral I/O interface is made through a configurable Wishbone Interconnect device (WB\_INTERCON).

For more information on connecting peripheral I/O devices to a processor, refer to the application note Connecting Memory and Peripheral Devices to a 32-bit Processor.

Mapping of slave peripheral I/O devices into the processor's address space is performed only from within the FPGA project, using the *Configure Peripheral* dialog (Figure 13). Access this dialog by right-clicking on the symbol for the processor (in the schematic) and choosing **Configure Processor Peripheral** from the context menu that appears. Alternatively, use the **Configure Processor Peripheral** button available from the *Component Properties* dialog for the processor.

| Configure Per                                                                                                                         | ipheral                                            |                          |                                        | ? 🛛                                                |  |
|---------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|--------------------------|----------------------------------------|----------------------------------------------------|--|
|                                                                                                                                       | Processor Architecture                             |                          | Defined Per<br>This is the processor's | ripheral Devices<br>view of the peripheral devices |  |
|                                                                                                                                       | OxFFFF_FFFF                                        |                          |                                        |                                                    |  |
| OxFFFF_FFFF                                                                                                                           | Processor I/O Space<br>IO Port<br>of the processor |                          |                                        |                                                    |  |
| OXFEFF_FFF                                                                                                                            | External-Memory Space                              |                          |                                        |                                                    |  |
| 0x0100_0000                                                                                                                           |                                                    |                          |                                        |                                                    |  |
| 0x0000 0000                                                                                                                           | Internal-Memory<br>Where the<br>boot code resides  |                          |                                        |                                                    |  |
|                                                                                                                                       | 0x0000_0000                                        | 1                        |                                        |                                                    |  |
| Name                                                                                                                                  | Address                                            | △ Size                   | Туре                                   | Interrupts                                         |  |
| Generate following files into the subproject(s) at FPGA Project compilation  hardware.asm (Assembly File)  hardware.h (C Header File) |                                                    |                          |                                        |                                                    |  |
| Set to <u>D</u> efaul                                                                                                                 | t Import From Schematic                            | <u>C</u> onfigure Memory | ]                                      | <u> </u>                                           |  |

Figure 13. Mapping peripheral devices into processor memory address space

The dialog is divided into two regions. The top region provides a visual summary of the peripheral devices that are currently defined and mapped into the processor's address space – i.e. the processor's 'view' of the actual peripherals in the design. The bottom region of the dialog provides a tabular listing of each of these defined peripheral devices.

Controls are also provided in the dialog for generating header files (Assembly or C) upon compilation of the FPGA project.

The dialog also provides a **Configure Memory** button – allowing you to quickly jump between peripheral and memory configuration dialogs. Note that when using this facility, you will be prompted to confirm whether you wish to save the configuration of the current dialog before proceeding to the other dialog.

### Importing Device Information from the FPGA Project Schematic

If you have connected your slave peripheral device(s) to the processor through a Wishbone Interconnect, then the simplest way to make these devices 'known' to the processor – and automatically have them mapped into the processor's address space – is to use the *Configure Peripheral* dialog's Import from Schematic feature.

Launched by clicking on the **Import From Schematic** button, the feature essentially scans the FPGA design for configurable Wishbone Interconnect devices. All detected interconnect devices, along with the slave devices associated to them, are presented in the *Choose Wishbone Items* dialog (Figure 14).

Prior to the dialog appearing, you will be given the choice of whether or not to delete any existing peripheral device definitions that have been added. If you have not yet configured the processor I/O space, or want to start over again from a 'blank canvas' as it were, then opting to delete here is the best course of action.

On the other hand, you may have already defined peripherals that you wish to keep. This can be the case when adding additional peripheral devices to an already wellestablished design. In this case, it is better to not to delete the existing definitions, but rather import just the addition(s).

Each slave peripheral device connected to an Interconnect is listed in the dialog, in terms of its identifier. This identifier is assigned as part of the slave device's definition when configuring the Interconnect. The dialog offers the ability to import selected



Figure 14. Selecting peripheral devices to import into processor address space.

devices or all devices associated to a given Interconnect, by clicking on the relevant entry in the **Import to Bus** column. Choose the peripheral devices you wish to import and click **OK**.

Importing will:

#### Allocating Address Space in a 32-bit Processor

- Add peripheral device definitions where they currently do not exist. The identifier of an Interconnect slave device defined when configuring the Interconnect will be used to name the peripheral device definition.
- Update any existing peripheral device definitions, only if the identifier of the Interconnect slave device matches that of an existing peripheral device definition.
- Preserve exisiting peripheral device definitions whose identifiers do not match those of the Interconnect slave devices being imported leaving hand-crafted definitions untouched.

Update to/preservation of existing peripheral definitions, will only be possible where you have opted to not delete the existing configuration before importing.

Only peripheral devices connected to the processor via a Wishbone Interconnect device will be imported using the Import From Schematic feature. If a single peripheral device is

connected directly to the processor's Peripheral I/O interface, it will not be imported and mapped. In this case, you will need to manually add a definition for the device.

Figure 15 illustrates an example of this mapping based on the example schematic circuitry of Figure 12.

| Configure Per                                                                                                                                         | ipheral                                            |                  |                                 |                                                | ? 🗙                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|------------------|---------------------------------|------------------------------------------------|----------------------------|
|                                                                                                                                                       | Processor Architecture                             | Th               | Defined P<br>is is the processo | Peripheral Device<br>r's view of the periphera | es<br>Idevices             |
|                                                                                                                                                       | OxFFFF_FFFF                                        |                  | 0                               | ×FFFF_FFFF                                     |                            |
| OxFFFF_FFFF                                                                                                                                           | Processor I/O Space<br>IO Port<br>of the processor |                  | U_                              | Port8<br>INTERCON_IO                           | 0xFF20_0003<br>0xFF20_0000 |
| OxFEFF_FFFF                                                                                                                                           |                                                    |                  | U_                              | Port16<br>INTERCON_IO                          | 0xFF10_0003<br>0xFF10_0000 |
|                                                                                                                                                       | External-Memory Space                              |                  | U_                              | Port32<br>INTERCON_IO                          | 0×FF00_0003<br>0×FF00_0000 |
| 0x0100_0000                                                                                                                                           |                                                    |                  |                                 |                                                |                            |
| OxOOFF_FFFF                                                                                                                                           | Internal-Memory<br>Where the<br>boot code resides  |                  |                                 |                                                |                            |
| <u>0x0000_0000</u>                                                                                                                                    | 0x0000_0000                                        |                  | 0                               | ×0000_0000                                     |                            |
| Name                                                                                                                                                  | Address                                            | △ Size           | Туре                            | Interrupts                                     |                            |
| Port32                                                                                                                                                | 0xFF000000                                         | 0x0004           | Peripheral                      |                                                |                            |
| Port16                                                                                                                                                | 0xFF100000                                         | 0x0004           | Peripheral                      |                                                |                            |
| Port8                                                                                                                                                 | 0xFF200000                                         | 0x0004           | Peripheral                      |                                                |                            |
| Generate following files into the subproject(s) at FPGA Project compilation           hardware.asm (Assembly File)         hardware.h (C Header File) |                                                    |                  |                                 |                                                |                            |
| Set to <u>D</u> efaul                                                                                                                                 | t Import From Schematic                            | Configure Memory |                                 | <u> </u>                                       | <u>C</u> ancel             |

Figure 15. Defining peripheral devices automatically by importing from the schematic.

If you do not wish to import any Interconnect-related devices, simply click on the **Skip** button (in the *Choose Wishbone Items* dialog).

### **Managing Peripheral Device Definitions**

New peripheral device definitions may be added, or existing ones modified or deleted, using the available commands on the right-click menu for the *Configure Peripheral* dialog. An existing peripheral device can also be modified with respect to its definition by double-clicking on its corresponding entry in the list section of the dialog, or by double-clicking on its 'block' in the graphical display. The associated *Peripheral Device* dialog will appear (Figure 16).

The dialog enables you to accurately define the peripheral device in terms of its size and base address – specifying where in the processor's address space it is to be mapped. You can specify these values using decimal or Hex notation (e.g. 10000, 0x10000, 1k, 64k, 1M).

The **Name** field allows you to define a unique identifier for the device. The identifier for each peripheral device will be used when generating header files for inclusion into the Embedded Software project (see next section). It is important to note that the identifier used must not contain spaces.

The Type region allows you to specify the type of peripheral. Choose between the following options:

- Peripheral standard peripheral device.
- **Peripheral ASP** a peripheral whose functionality is described in the Embedded Software project.

The **Interrupts** region of the dialog allows you to assign the required interrupt lines to the slave device. For devices that generate multiple interrupts, assignment is made by entering a comma-separated list.

| Peripheral Device         Name         Port32         The unique identifier of this peripheral device.         When the FPGA project is compiled these peripheral details will be passed to the peripheral device appears in the address pane device software project in the form of peripheral. Any peripheral device.         Names cannot contain a definition for device.         Peripheral device.         Names cannot contain spaces.         Peripheral         Choose the kind of peripheral it is.         Either it is a normal peripheral or an ASP peripheral whose functionality is described in the embedded project.         Interrupts         This represents the list of interrupts to be assigned to the device.         Interrupts         Chis represents the list of interrupts to be assigned to the device.         Interrupts         Chis represents the list of interrupts to be assigned to the device.         Interrupts         Chis represents the list of interrupts to be assigned to the device.         Interrupts         Interrupts | eripheral Device                                                                                                                                                                                                          | · · · · · · · · · · · · · · · · · · ·                                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| peripheral.h or periphera.asm.         The generated file will contain a definition for the address and size of the peripheral. This definition will have the same name as the peripheral device.         Names cannot contain spaces.         Type         Peripheral         Peripheral         Choose the kind of peripheral it is.         Either it is a normal peripheral or an ASP peripheral whose functionality is described in the embedded project.         Interrupts         This represents the list of interrupts to be assigned to the device.         This represents the list of interrupts to be assigned to the device.         Enter as a comma delimited list.         Example: 1, 5, 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | eripheral Device Peripheral Device Name Port32 The unique identifier of this peripheral device. When the FPGA project is compiled these peripheral details will be passed to the embedded software project in the form of | Address Base OxFF000000 This is the processor's view of where the peripheral device appears in the address space. The size can be specified as a decimal or hex                     |
| Type       Inits represents the antodix device.         Peripheral       Interrupts         Choose the kind of peripheral it is.       Examples: 10000, 0x10000, 1k, 64k, 1M         Either it is a normal peripheral or an ASP peripheral whose functionality is described in the embedded project.       Interrupts         Interrupts       Interrupts         Line ray a comma definited list.       Example: 1, 5, 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | The generated file will contain a definition for<br>the address and size of the peripheral. This<br>definition will have the same name as the<br>peripheral device.                                                       | Size Ox0004 This serves to the amount of memory that is                                                                                                                             |
| Litter in the only base functionality is         described in the embedded project.         This represents the list of interrupts to be assigned to the device.         Enter as a comma delimited list.         Example: 1, 5, 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type<br>Peripheral<br>Choose the kind of peripheral it is.                                                                                                                                                                | This represents the aniotic of mentoy that is allocated to this peripheral device.<br>The size can be specified as a decimal or hex value.<br>Examples: 10000, 0x10000, 1k, 64k, 1M |
| <u> </u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | peripheral whose functionality is<br>described in the embedded project.                                                                                                                                                   | This represents the list of interrupts to be<br>assigned to the device.<br>Enter as a comma delimited list.<br>Example: 1, 5, 17                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                           | <u>D</u> K <u>C</u> ancel                                                                                                                                                           |

Figure 16. Defining a mapped peripheral I/O device.

## **Generating Header Files for the Embedded Software Project**

When mapping slave memory and peripheral I/O devices to the processor's address space from within the FPGA project, the *Configure Processor Memory* and *Configure Peripheral* dialogs provide two options for passing the memory and peripheral definition information to the Embedded Software project:

- hardware.asm (Assembly File)
- hardware.h (C Header File)

The option you choose will depend on whether the embedded source code is written in Assembly or C. In each case, when the FPGA project is compiled, the chosen definition file will be created and added to the Embedded Project.

A header file essentially provides keyword substitution. The Embedded Software designer can simply enter a definition into the code, which, through the header file, will be substituted with the required information at compile time. It is far easier to remember and use identifiers for device addresses and sizes, rather than the hexadecimal representations themselves.

For each mapped memory and peripheral device, the file will contain the following definitions:

- The device's base address. The name for this entry will appear in the form Base\_DeviceIdentifier (e.g. Base\_EMAC32).
- The device's size. The name for this entry will appear in the form Size\_DeviceIdentifier (e.g. Size\_EMAC32).

For those peripheral devices that generate interrupts to the processor, the corresponding interrupt definitions will also be listed. The name for an interrupt entry will be of the form:

#### $\verb"Intr_DeviceIdentifier_InterruptIndex"$

where *InterruptIndex* is an alpha suffix (A, B, C, etc) to distinguish between multiple interrupts from the same device. Consider for example a BT656 Video Capture Controller, with the identifier Video, and which generates two interrupts to the host 32-bit processor. The interrupt name entries for this device in a generated header file would be:

Intr\_Video\_A

Intr\_Video\_B

Figure 17 shows an example of two generated header files – one C, the other Assembly.

Enabling or disabling an option in one dialog will automatically enable/disable the corresponding option in the other dialog.

DeviceIdentifier is the unique name assigned to the memory or peripheral device as part of its definition when mapping.

#### Allocating Address Space in a 32-bit Processor

| h h | ardware.h                                                                                                                                                                         | »<br>•   | ) 👩 hardware.asm 💝                                                                                                                                   |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | <pre>// // Automatically generated header file. // Generated: 10:47:45 PM 11/07/2006 // This file should not be edited. // #ifndefHARDWARE_H #define HARDWARE_H</pre>             |          | ; Automatically generated header file.<br>; Generated: 10:47:45 EM 11/07/2006<br>; This file should not be edited.<br>;<br>Base LEDS .equ 0xFF000000 |
|     | //                                                                                                                                                                                |          | Size_LEDS .equ 0x00000001                                                                                                                            |
|     | <pre>// #define Base_SRL0 0xFF300000 #define Size_SRL0 0x00000010 #define Intr_SRL0_A 2 //</pre>                                                                                  |          | Intr_SRLO_A .equ 2<br>                                                                                                                               |
|     | //#define Base_EMAC32 0xFF100000<br>#define Size_EMAC32 0x00000020<br>#define Intr_EMAC32_A 0<br>//                                                                               |          | Intr_EMAC32_A .equ 0<br>                                                                                                                             |
|     | <pre>#define INTERRUPT_CONTROL_CFG 0x00000005 #define INTERRUPT_KINDS_CFG 0x0000000 #define INTERRUPT_EDGE_KIND_CFG 0x00000000 #define INTERRUPT_LVL_KIND_CFG 0x00000005 //</pre> |          | #define INTERRUPT_LVL_KIND_CFG 0x00000005<br>//<br>Base_U_MCU1 .equ 0x00000000<br>Size_U_MCU1 .equ 0x00008000                                        |
|     | #define Base_U_MCU1 0x00000000<br>#define Size_U_MCU1 0x00008000<br>//                                                                                                            |          | Base_EXT_RAM .equ 0x01000000<br>Size_EXT_RAM .equ 0x00100000                                                                                         |
|     | #define Base_EXT_RAM 0x01000000<br>#define Size_EXT_RAM 0x00100000<br>//<br>#endif //HARDWARE_H_                                                                                  |          |                                                                                                                                                      |
|     |                                                                                                                                                                                   | <u> </u> |                                                                                                                                                      |

Figure 17. Example of generated hardware definition files for use by the embedded software.

## **Revision History**

| Date        | Version No. | Revision                              |
|-------------|-------------|---------------------------------------|
| 14-Jul-2006 | 1.0         | Initial release                       |
| 27-Feb-2008 | 2.0         | Updated for Altium Designer Summer 08 |

Software, hardware, documentation and related materials:

Copyright © 2008 Altium Limited.

All rights reserved. You are permitted to print this document provided that (1) the use of such is for personal use only and will not be copied or posted on any network computer or broadcast in any media, and (2) no modifications of the document is made. Unauthorized duplication, in whole or part, of this document by any means, mechanical or electronic, including translation into another language, except for brief excerpts in published reviews, is prohibited without the express written permission of Altium Limited. Unauthorized duplication of this work may also be prohibited by local statute. Violators may be subject to both criminal and civil penalties, including fines and/or imprisonment. Altium, Altium Designer, Board Insight, Design Explorer, DXP, LiveDesign, NanoBoard, NanoTalk, P-CAD, SimCode, Situs, TASKING, and Topological Autorouting and their respective logos are trademarks or registered trademarks of Altium Limited or its subsidiaries. All other registered or unregistered trademarks referenced herein are the property of their respective owners and no trademark rights to the same are claimed.