## gmZPU SoC Datasheet

## Koen Martens kmartens@sonologic.nl

March 15, 2014

#### 1 Introduction

The gmZPU System-on-Chip (SoC) combines the zpu zealot medium core [2] with two WISHBONE B4 [1] buses. One of the WISHBONE buses connects internal devices to the zpu. The other WISHBONE bus is exported for external devices. Figure 1 shows the top-level block diagram of the gmZPU SoC.

The zpu data bus is 32 bits wide. The address bus is 18 bits wide. The Memory Management Unit (MMU) decodes the 18-bit address into chip-select and reduced address bus for the main components of the SoC interconnect fabric:

- RAM
- phiIO basic zpu I/O
- WISHBONE controller 0 (WB0)
- WISHBONE controller 1 (WB1)

#### 2 Notation

BUS(1:0) Bit 1 downto 0 of bus BUS.

### 3 Memory map

The 8 most significant bits of the zpu address bus select one of the core components linked directly to the zpu. Table 1 shows how these bits are decoded.

Table 1: Address decoding

|   | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | chip select |
|---|----|----|----|----|----|----|----|----|-------------|
|   | 0  | X  | X  | X  | X  | X  | X  | X  | RAM         |
|   | 1  | 0  | X  | X  | X  | X  | X  | X  | phiIO       |
| ĺ | 1  | 1  | 0  | X  | X  | X  | X  | X  | WB0 control |
|   | 1  | 1  | 1  | 0  | 0  | 0  | 0  | X  | WB0 slave 0 |
|   | 1  | 1  | 1  | 0  | 0  | 0  | 1  | X  | WB0 slave 1 |

Each core component has a specific address bus width. Table 2 shows the base address of each of the core components shown in 1. Along with the base address is the size of the address bus to that device.

Table 2: Address map and sizes

| Device      | Base    | Size    | Bytes |
|-------------|---------|---------|-------|
| RAM         | 0x00000 | 0x20000 | 128k  |
| phIO        | 0x20000 | 0x10000 | 64k   |
| WB0 control | 0x30000 | 0x08000 | 32K   |
| WB0 slave 0 | 0x38000 | 0x00800 | 2K    |
| WB0 slave 1 | 0x38800 | 0x00800 | 2k    |



Figure 1: Block diagram

#### 4 Internal devices

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vestibulum tempor ipsum sit amet mauris ornare, eget tincidunt mauris bibendum. Phasellus tincidunt vulputate dignissim. Suspendisse blandit aliquam ante, at commodo diam tincidunt sit amet. Donec ut scelerisque mi. Proin ipsum justo, convallis vitae ante ut, porta bibendum nunc. Nunc nisi turpis, tincidunt non lorem eu, euismod dignissim tellus. Mauris suscipit, augue quis eleifend tristique, libero eros molestie orci, vitae pretium ipsum metus vel dui. Nullam condimentum, est vel congue lacinia, tellus tortor vestibulum neque, vel pulvinar neque orci non odio.

Donec tempor risus orci, vel sodales turpis mattis sit amet. Nullam elementum adipiscing nulla, sed commodo purus posuere id. Donec sollicitudin ullamcorper interdum. Praesent ultrices et lacus a condimentum. Curabitur porttitor, libero in tristique aliquam, enim leo rutrum metus, vel interdum nisi ligula vel libero. Duis hendrerit urna scelerisque nulla convallis facili-

sis. Maecenas in tellus orci. Duis ante metus, mollis a ligula non, aliquet tempor leo. Donec at ante mauris.

Maecenas lobortis vulputate lobortis. Nunc pulvinar convallis tortor eu luctus. Sed vehicula ipsum a neque dictum, sed ornare dolor luctus. Curabitur hendrerit dui et ante rhoncus vulputate. Curabitur a nibh ultricies, ornare eros sit amet, pharetra sapien. Vestibulum venenatis convallis feugiat. Nulla leo turpis, facilisis vitae velit ac, dignissim blandit quam. Sed vehicula metus sit amet imperdiet ullamcorper. Etiam eget cursus orci, vitae ultrices est. Vivamus ac quam tincidunt, porta orci at, vehicula mi. Integer eros massa, egestas vitae facilisis eleifend, iaculis auctor ligula.

# 4.1 Programmable Interrupt Controller (PIC)

Donec non pulvinar sem. Mauris elementum euismod vulputate. In a pretium massa. Quisque lacus enim, euismod ut dapibus sed, pretium at purus. Etiam eu massa erat. Nam semper, arcu eu mollis eu-

ismod, tellus lacus scelerisque ligula, in cursus orci quam eu odio. Vivamus tincidunt consectetur neque a tempus. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse velit lorem, consequat in sapien in, vulputate cursus nisl. Aenean rutrum nisi eu ligula vulputate vulputate. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vivamus risus tortor, imperdiet et sollicitudin convallis, ultricies interdum massa. Sed volutpat enim id mauris facilisis rhoncus.

Donec molestie fermentum sodales. Ut pellentesque dolor non nulla commodo dignissim. Etiam nec porta est, a porta odio. Nam eu fermentum metus. Ut elit libero, porttitor ac lacus ac, ornare tempus lacus. Cras ac ultricies nisi. Nunc porttitor massa non erat blandit dapibus. In hac habitasse platea dictumst. In hac habitasse platea dictumst. Praesent ac aliquet quam. Cras mattis lectus et metus laoreet fringilla. Donec viverra sem at iaculis lacinia. Integer lorem augue, aliquet vel fringilla eget, consectetur malesuada lorem. Cras quis tortor vitae lacus fermentum bibendum id nec diam. Curabitur tempus, turpis ac cursus pretium, augue metus commodo nisi, non hendrerit mi justo eu nisl.

- [2] Zylin Consulting Zylin ZPU http://opensource.zylin.com/zpu.htm.
- [3] Sonologic gmzpu github repository http://github.com/sonologic/gmzpu.

### References

[1] OpenCores Wishbone B4, WISHBONE System-on-Chip (SoC)Interconnection Architecture for Portable IP Cores http://opencores.org/opencores, wishbone 2010.