**Title**

HW-SW SystemC Co-Simulation SoC Validation Platform

**IP User Manual**

Contract No. 4200022968

by

![](data:image/x-wmf;base64,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cgQJAAAAHQYhAPAAAgCPAD8A/QAJAAAAHQYhAPAAAQCTAUAAXwIJAAAAHQYhAPAAAQBQAEAAcQQJAAAAHQYhAPAAAwCUAD8AAAAJAAAAHQYhAPAAAQCQAEEA/AAJAAAAHQYhAPAAAQCQAEIA+wAJAAAAHQYhAPAAAgCTAUEAXgIJAAAAHQYhAPAAAgBRAEEAcAQJAAAAHQYhAPAAAgCTAEIAAAAJAAAAHQYhAPAAAQCRAEMA+gAJAAAAHQYhAPAAAQCTAUMAXQIJAAAAHQYhAPAAAQBSAEMAbwQJAAAAHQYhAPAAAQCQAEQA+gAJAAAAHQYhAPAAAQCTAUQAXAIJAAAAHQYhAPAAAQBTAEQAbgQJAAAAHQYhAPAAAQCRAEUA+QAJAAAAHQYhAPAAAQCTAUUAWwIJAAAAHQYhAPAAAwCSAEQAAAAJAAAAHQYhAPAAAQCSAEYA+AAJAAAAHQYhAPAAAgBUAEUAbQQJAAAAHQYhAPAAAQCRAEcA+AAJAAAAHQYhAPAAAgCTAUYAWgIJAAAAHQYhAPAAAQBVAEcAbAQJAAAAHQYhAPAAAQCSAEgA9wAJAAAAHQYhAPAAAQCTAUgAWQIJAAAAHQYhAPAAAwCRAEcAAAAJAAAAHQYhAPAAAQCTAEkA9gAJAAAAHQYhAPAAAQCTAUkAWAIJAAAAHQYhAPAAAgBWAEgAawQJAAAAHQYhAPAAAQBXAEoAagQJAAAAHQYhAPAAAgCQAEoAAAAJAAAAHQYhAPAAAgCTAEoA9QAJAAAAHQYhAPAAAgCTAUoAVwIJAAAAHQYhAPAAAQBYAEsAaQQJAAAAHQYhAPAAAQCTAEwA9AAJAAAAHQYhAPAAAQCTAUwAVgIJAAAAHQYhAPAAAQCTAU0AVQIJAAAAHQYhAPAAAgBZAEwAaAQJAAAAHQYhAPAAAwCPAEwAAAAJAAAAHQYhAPAAAgCUAE0A8wAJAAAAHQYhAPAAAQCSAU4AVQIJAAAAHQYhAPAAAQBaAE4AZwQJAAAAHQYhAPAAAQCUAE8A8gAJAAAAHQYhAPAAAQCTAU8AVAIJAAAAHQYhAPAAAgCOAE8AAAAJAAAAHQYhAPAAAQCVAFAA8QAJAAAAHQYhAPAAAQCTAVAAUwIJAAAAHQYhAPAAAgBbAE8AZgQJAAAAHQYhAPAAAQCUAFEA8QAJAAAAHQYhAPAAAQCTAVEA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fgBhAn0AYAJ9AF4CfABdAnwAWwJ7AFoCewCrAgYArgIGALACBwC1AgcAuAIIALoCCAC9AgkAvwIJAMICCgDEAgoAxwILAMkCCwDMAgwAzgIMANACDQDTAg4A1QIPANcCDwDZAhAA2wIRAN4CEgDgAhMA4gIUAOQCFQDmAhYA6AIXAOoCGADsAhkA7gIaAPACGwDyAh0A9AIeAPkCIgD+AiYABwMvAAoDNAAOAzoAEQM/ABQDRQAWA0oAGANQABoDVgAbA10AHANjAB0DagAeA3AAHgOFAB0DjAAdA5QAHAObABsDogAZA6oAGAOxABYDuQAUA8AAEgPIABADzwAOA9cACwPeAAkD5gAGA+0AAwP1AP8C/QD8AgUB+AINAfQCFgHvAh4B6wImAeYCLgHiAjYB3AI9AdcCRQHSAk0BzAJVAccCXAHBAmMBugJrAbQCcgGgAoYBmQKMAZECkgGKApgBggKeAXoCpAFyAqkBagKuAWICsgFZArcBUAK7AUcCvwE+AsIBOALEATMCxgEtAscBKALJASICygEcAssBFwLMARECzQEMAs4BBgLPAQEC0AH7AdEB9gHRAfAB0gHrAdMB4AHTAdoB1AHKAdQBxQHVAWcB1QG8AWABFgAAACQDCQDABAQAwATVASsE1QEvBJgBmwOYAeEDNwE3BDcBOwS7AMAEBAADAAAAAAA=)TU Braunschweig, Germany

December 13, 2010

**Document No.: IDA-SCSV-UM-001**

**Table of Contents**

1 Introduction 5

1.1 Purpose and Scope 5

1.2 Referenced Documents 5

1.3 Revisions 5

2 Installation & Dependencies 6

2.1 Required Software Packages 6

2.2 Installing GreenSocs Software 6

2.3 Building IP Model Library and Tests 7

3 AMBA Kit 9

3.1 Concepts 9

3.2 Coding AMBA Masters and Slaves 9

3.3 The Simple\_System Example 11

4 Aeroflex Gaisler GRLIB MCTRL Memory Controller 14

4.1 Functionality and Features 14

4.1.1 Overview 14

4.1.2 Address Space 14

4.1.3 Memory Access 17

4.1.4 SDRAM Modes of Operation 19

4.2 Internal Structure 21

4.2.1 The mctrlreg.h File 21

4.2.2 The mctrl.h File 21

4.2.3 The mctrl.tpp File 22

4.3 Parametrization Options 23

4.4 Interface 25

4.4.1 APB Bus Communication 25

4.4.2 AHB Bus Communication 25

4.4.3 Memory Device Interface 25

4.5 Compilation Instructions 25

4.6 Example Instantiation 26

5 Memory Model 27

5.1 Functionality and Features 27

5.2 Internal Structure 27

5.2.1 The generic\_memory.h File 27

5.2.2 The generic\_memory.tpp File 27

5.3 Parametrization Options 28

5.4 Interface 28

5.5 Compilation Instructions 28

5.6 Example Instantiation 28

6 CACHE Sub-systeM 29

6.1 Functionality and Features 29

6.1.1 Overview 29

6.1.2 Address Space Identifiers (ASI) 30

6.1.3 System and Control Registers 31

6.1.4 Diagnostic Access 33

6.1.5 Payload Extensions 33

6.1.6 Debug Mechanism 34

6.2 Internal Structure 35

6.2.1 The defines.h file 35

6.2.2 The payload\_extension files 35

6.2.3 The mem\_if.h file 36

6.2.4 The mmu\_cache\_if.h file 37

6.2.5 The mmu\_cache.h/cpp files 37

6.2.6 The vectorcache.h/cpp files 38

6.2.7 The ivectorcache.h/cpp files 39

6.2.8 The dvectorcache.h/cpp files 40

6.2.9 The localram.h/cpp files 40

6.2.10 The mmu.h/cpp files 40

6.2.11 The tlb\_adaptor.h file 41

6.3 Parametrization Options 41

6.4 Interface 43

6.5 Compilation Instructions 43

6.6 Example Instantiation 44

7 Aeroflex Gaisler GPTIMER General Purpose Timer 46

7.1 Functionality and Features 46

7.2 Internal Structure 47

7.2.1 The gptimer.h/tpp files 47

7.2.2 The gptimerregisters.h file 48

7.3 Parametrization Options 48

7.4 Interface 48

7.5 Compilation Instructions 48

7.6 Example Instantiation 49

8 Aeroflex Gaisler IRQMP Interrupt Controller 49

8.1 Functionality and Features 49

8.1.1 Overview 49

8.1.2 Interrupt Prioritization and Forwarding 50

8.1.3 Extended Interrupt Handling 52

8.1.4 Processor Status Monitoring 52

8.2 Internal Structure 52

8.2.1 The irqmpregisters.h File 52

8.2.2 The irqmp.h File 52

8.2.3 The irqmp.tpp file 53

8.3 Parametrization Options 54

8.4 Interface 54

8.4.1 APB Bus Communication 54

8.4.2 Direct Processor Communication 55

8.5 Compilation Instructions 55

8.6 Example Instantiation 56

9 SocWire 56

9.1 Functionality and Features 56

9.2 Internal Structure 57

9.3 Parametrization Options 57

9.4 Interface 57

9.5 Compilation Instructions 57

9.6 Example Instantiation 57

10 GRLib Plug & Play mechanism 57

10.1 Example Instantiation 58

**Table of Figures**

Figure 1 - AMBAKit / Initiate Transaction 9

Figure 2 - AMBA Slave / blocking transport 11

Figure 3 - Simple\_System Test 12

Figure 4 – RAM address space 16

Figure 5 - Structure of Cache Sub-System 30

Figure 6 - Generic Memory Interface / Dependencies 37

Figure 7 – Interrupt Distribution Scheme 51

**Table of Tables**

Table 1 - Referenced Documents 6

Table 2 - Revisions of this document 6

Table 3 - Software Dependencies 7

Table 4 – MCTRL Registers 15

Table 5 – MCTRL Template Parameters 26

Table 6 - Supported ASIs 32

Table 7 - CACHE CONTROL REGISTER 32

Table 8 - ICACHE & DCACHE Configuration Register 33

Table 9 - MMU Control Registers 34

Table 10 - Debug Extension 35

Table 11 - TLM Sockets Cache Sub-System 39

Table 12 - Page size / index combinations 42

Table 13 - Constructor Configuration Parameters 43

Table 14 - Constructor Simulation Parameters 44

Table 15 - Tests Cache Sub-System 45

Table 16 – GPTimer Registers 47

Table 17 - GPTimer Parameters 49

Table 18 - Timer SignalKit sockets 49

Table 19 – IRQMP Registers 51

Table 20 - Template Parameters 55

# Introduction

## Purpose and Scope

This document is a user manual (UM) of the SystemC transaction level models developed in the HW-SW SystemC Co-Simulation SoC Validation Platform project.

In compliance with the SoW, the „UM describes the IP interface and functions and its use from the perspective of the system architect and the programmer, including examples.“

## Referenced Documents

The following table will be updated during the development of the UM.

|  |  |  |
| --- | --- | --- |
| **Reference** | **Document Number** | **Document Title, Author** |
| RD01 | TEC-EDM/2008.27/BG | Statement of Work to ITT- AO/1-6025/09/NL/JK, ESA |
| RD02 | IDA-PPS-0309-2 | HW-SW Co-Simulation SystemC SoC Validation Platform – Technical Proposal |
| RD03 | IDA-PPS 0309-3 | HW-SW Co-Simulation SystemC SoC Validation Platform – Management Proposal |
| RD04 |  | GRLIB IP Core User’s Manual |
| RD05 |  | GRLIB IP Library User’s Manual |
| RD06 |  | GreenSocs AMBA LT/AT concepts |
| RD07 |  | GreenSocs AMBA TLM 2.0 Extensions |
| RD08 |  | SPARC V8 Reference Manual |
|  |  |  |

Table 1 - Referenced Documents

## Revisions

|  |  |  |
| --- | --- | --- |
| **Version** | **Date** | **Description** |
| 1.0 | 01/09/10 | Initial submission |
| 1.1 | 17/09/10 | Version prior to the MDR meeting |
|  |  |  |

Table 2 - Revisions of this document

# Installation & Dependencies

## Required Software Packages

The Model Library can be checked out from our SVN repository at following location:

<https://ntserv1.ida.ing.tu-bs.de/svn/hwswcosim/trunk>

To compile and simulate the models following external dependencies are needed (Table 2).

| Tool / Lib | Version | Vendor | Installation Path Variables |
| --- | --- | --- | --- |
| Python | >2.3 | Python team | On **$PATH** |
| GCC (x86) | 4.1.0 | GCC team | On **$PATH** |
| GMP | 5.0.0 | GCC team | On **$PATH** |
| MPFR | 2.4.2 | GCC team | On **$PATH** |
| binutils | 2.19 | GNU team | On **$PATH** |
| Boost | 1\_37\_0 | Boost team | **$BOOST\_DIR** - header path  **$BOOST\_LIB** - library path |
| SystemC | 2.2.0 | OSCI | **$SYSTEMC\_HOME** – installation root |
| SCV |  | OSCI | **$SCV\_HOME** – installation root |
| TLM 2.0 | 2009-07-15 | OSCI | **$TLM2\_HOME** – installation root |
| GreenSocs | 4.0.0 | GreenSocs Ltd. | **$GREENSOCS\_HOME** – installation root |
| AMBAKit | trunk | GreenSocs Ltd. | **$AMBA\_HOME** – installation root |

Table 3 - Software Dependencies

Please make sure that all the software packages mentioned above are properly installed before the library ist build.

## Installing GreenSocs Software

### GreenSocs

The GreenSocs Library can be downloaded from the following location:

<http://www.greensocs.com/files/greensocs-4.0.0.tar.gz>

Extract the tarball to a folder on your build system:

$ tar -xvzf greensocs-4.0.0.tar.gz

Make sure the following shell variables hold paths to the corresponding libraries:

$ export SYSTEMC\_HOME=<THE **ROOT** OF YOUR SYSTEMC INSTALLATION>

$ export TLM\_HOME=<THE **ROOT** OF YOUR TLM2.0 INSTALLATION>

$ export BOOST\_DIR=<THE **INCLUDE** DIR OF YOUR BOOST INSTALLATION>

$ export GREENSOCS\_HOME=<THE FOLDER YOU **EXTRACTED** GREENSOCS>

$ export GSGPSOCKET\_DIR=$GREENSOCS\_HOME/gsgpsocket

$ export GREENSOCKET\_DIR=$GREENSOCS\_HOME/greensocket

$ export GREENREG\_DIR=$GREENSOCS\_HOME/greenreg

$ export GREENCONTROL\_DIR=$GREENSOCS\_HOME

Change to the greensocs-4.0.0/greenreg folder and make a small change in the **Makefile.conf**:

Comment out the 2nd to 4th lines with #:

2 TOP := $(dir $(lastword $(MAKEFILE\_LIST)))

3

4 GREENREG\_DIR=$(TOP)

to:

2 **#**TOP := $(dir $(lastword $(MAKEFILE\_LIST)))

3 **#**

4 **#**GREENREG\_DIR=$(TOP)

Compile the GreenReg library:

$ make

A static library is build in the GreenReg directory. This is needed by the model library for the APB modules.

Now the GreenSocs library is ready to use with our model library.

Simply export the GreenSocs root directory as GREENSOCS\_HOME:

$ export GREENSOCS\_HOME=<THE FOLDER YOU **EXTRACTED** GREENSOCS>

Or use the waf configuration parameter –greensocs with the greensocs root directory of the model library:

$ ./waf configure –greensocs=<THE FOLDER YOU **EXTRACTED** GREENSOCS>

It is recommended to apply the AMBAKit Sockets patch to the GreenSocs library. This enables you to build your own models with GreenReg and AMBA Sockets outside the model library. Anyway the model library arrives with a workaround.

### AMBA Kit

The AMBAKit is not officially released therefore you should have your own copy of the Kit.

Extract the tarball to a folder on your build system:

$ tar -xvzf AMBAKit-trunk.tar.gz

The AMBAKit is like the TLM Library only a collection of headers. Just export the location to the build system of de model library:

$ export AMBA\_HOME=<THE FOLDER YOU **EXTRACTED** THE AMBAKIT>

Or use the waf configuration parameter –amba with the greensocs root directory of the model library:

$ ./waf configure –amba=<THE FOLDER YOU **EXTRACTED** THE AMBAKIT>

## Building IP Model Library and Tests

The build system is written in **waf**. All dependencies will be checked before the compilation of the project begins. The **waf** binary is located in the project root. It requires at least python 2.3 to run.

Do a “**./waf –h**” to get help on all available commands and options.

waf [command] [options]

Building the project requires following steps:

1. Execute “**./waf configure**” – to configure the build environment:

The configuration step succeeds in case all the required software packages are available. Otherwise, it fails and shows the broken dependency. If so, the install path variable must be corrected. It is also possible to specify the location of a missing package by one of the following options:

Common Configuration Options:

-b BLDDIR, --blddir=BLDDIR

build dir for the project (configuration)

-s SRCDIR, --srcdir=SRCDIR

src dir for the project (configuration)

--prefix=PREFIX installation prefix (configuration) [default: '/usr/local/']

--download try to download the tools if missing

--cxxflags=CXXFLAGS

C++ compiler flags

C++ Compiler Configuration Options:

--check-cxx-compiler=CHECK\_CXX\_COMPILER

On this platform (linux) the following C++ Compiler will be checked by default: "g++ icpc sunc++"

Boost Configuration Options:

--boost=BOOST\_HOME Basedir of your Boost installation

--boost\_inc=BOOST\_INC

Include dir of your Boost installation

--boost\_lib=BOOST\_LIB

Library dir of your Boost installation

SystemC configuration Options:

--systemc=SYSTEMC\_HOME

Basedir of your SystemC installation

--tlm2=TLM2\_HOME Basedir of your TLM-2.0 distribution

--tlm2tests=TLM2\_TESTS

Example of your TLM-2.0 distribution

--scv=SCV\_HOME Basedir of your SCV distribution

GreenSoCs Configuration Options:

--greensocs=GREENSOCS\_HOME

Basedir of your GreenSoCs instalation

--amba=AMBA\_HOME Basedir of your AMBAKit distribution

--grlib=GRLIB\_HOME Basedir of your grlib distribution

--ambaexamples=AMBA\_EXAMPLES

Basedir of your AMBAKit Examples

1. Execute “**./waf**” – to build all models and tests.  
     
   As an alternative you may select a specific target (test or library) using   
   “**./waf --targets=”list,of,targets”**”.   
     
   A list of targets can be generated with “**./waf list**”.
2. Execute “**./waf docs**” – to generate the source doxygen documentation.

# AMBA Kit

## Concepts

The IP components introduced in the document depend on the AMBAKit of GreenSocs Inc. This chapter is not intended to replace the documentation of GreenSocs. It can be seen as a supplement, though. The main goal is to outline how the components of the AMBAKit can be used in conjunction with the IP described in the remainder of this document.

The core of the AMBAKit is a flexible TLM2 bus model for simulation of an ARM AMBA bus. The bus model supports cycle-accurate (CT), approximately timed (AT) and loosely timed (LT) TLM2 coding style and implements the AXI, AHB and APB protocol. A single adapter is used to model LT and AT busses. This adapter is capable of transparently translating LT to AT transactions and the other way round. For the connection of LT/AT to CT components, the Kit provides a dedicated adapter. Moreover, it contains a template for a CT/RTL adapter, which may be used to build transactors for SystemC/VHDL co-simulation.

## Coding AMBA Masters and Slaves

The AMBAKit itself contains many examples. All bus-protocols/types are tested in various configurations. Moreover, it is shown how the different master-, slave- and bridge-components are supposed to be connected and how transactions on different levels of abstractions can be translated in one another.

In the following the usage of AMBAKit will be shown on the small example of an AMBA master and an AMBA slave module.

1 class amba\_master : public amba\_master\_socket<32> {  
 2     public:  
 3         amba\_master( sc\_module\_name \_name, amba\_bus\_type \_type,   
 4         amba\_layer\_ids \_layer, bool \_arbiter)  
 5         : amba\_master\_socket<32>(\_name, \_type, \_layer, \_arbiter) {}  
 6   
 7         void write(uint32\_t addr, unsigned char \*data, uint32\_t length) {  
 8             sc\_core::sc\_time t;  
 9             tlm::tlm\_generic\_payload \*gp = amba\_master.get\_transaction();  
10             gp->set\_command(tlm::TLM\_WRITE\_COMMAND);  
11             gp->set\_address(addr);  
12             gp->set\_data\_length(length);  
13             gp->set\_streaming\_width(length);  
14             gp->set\_byte\_enable\_ptr(NULL);  
15             gp->set\_data\_ptr(data);  
16             amba\_master->b\_transport(\*gp,t);  
17             wait(t);  
18             amba\_master.release\_transaction(gp);  
19         }  
20 };

Figure 1 - AMBAKit / Initiate Transaction

Figure 1 illustrates the initiation of a transaction within an AMBA master module. First an object of type *tlm\_generic\_payload* is retrieved from the transaction pool of the AMBA master socket. The payload object can also be newly created. Though, for performance reasons it is recommended to reuse existing objects. Afterwards the various attributes of the payload object are initialized by calling the appropriate payload member functions. In the most simple case, which is shown here, the payload receives information about the target address, the number of bytes to be transferred and the streaming width. The request may be a TLM\_WRITE\_COMMAND or a TLM\_READ\_COMMAND. In case of a write the *set\_data\_ptr* function receives a pointer to the data to be written as an argument. Read requests also require a data pointer. In that case, the slave copies the data directly to the given target address. The transaction is started by calling the transport function of the master socket (*master\_sock->b\_transport*). The transport function requires two arguments: the address of the payload object and a delay pointer. In a blocking communication the delay is incremented by the target component and by all transfer components (busses, bridges) the transaction passes through. After return of the transport function the master advances the system time by calling the SystemC wait function. Finally, the payload object can be released (*amba\_master.release\_transaction*). That means it goes back to the transaction pool, waiting to be allocated again. For non-blocking communication the structure of the master is more complicated, because the slaves are allowed to independently advance the simulation time (call wait). Respectively, the state of a transaction has to pass through multiple phases along a well-defined protocol.

The structure of an AMBA slave component for blocking communication is shown in Figure 2. To be able to react on incoming transactions, each slave has to implement a transport function. First the latter is ought to be registered at the slave socket (amba\_slave::register\_b\_transport). The transport function expects a payload pointer and a delay pointer as arguments. In the function body the payload object is extracted. First the information about target address and access type are evaluated (*gp.get\_address(), gp.is\_write(), gp.is\_read()*). Depending on the functionality of the component, the data is now directly read/written or other transactions are started (e.g. router). Afterwards the function returns. At AT-level each phase of the bus protocol must be executed one by one. This is mostly implemented within the AMBA sockets and not in all aspects visible to the user. Nevertheless, master and slave thread rotationally receive control in order to prepare the following protocol step, similar to real hardware. For more detailed information please see RD06 and RD07.

 1 class amba\_slave : public amba\_slave\_socket<32> {  
 2     public:  
 3         amba\_slave( sc\_module\_name \_name, gr\_uint\_t \_base\_address,   
 4                     gr\_uint\_t \_decode\_size, amba\_bus\_type \_type,   
 5                     amba\_layer\_ids \_layer, bool \_arbiter)  
 6         : amba\_slave\_socket<32>(\_name, \_type, \_layer, \_arbiter)  
 7         , m\_base( \_base\_address), m\_high( \_base\_address + \_decode\_size) {  
 8             // Bind amba blocking ...  
 9             amba\_slave::register\_b\_transport(this, &amba\_slave::b\_transport);  
10         }  
11         void b\_transport(tlm::tlm\_generic\_payload& gp, sc\_core::sc\_time&) {  
12             unsigned int addr = gp.get\_address() - m\_base;  
13             unsigned int length, msk, data;  
14             transaction\_type trans(this, &gp);  
15             if(gp.is\_write()) {  
16                 length = gp.get\_data\_length();  
17                 msk = len2mask(length);  
18                 memcpy(&data, &(gp.get\_data\_ptr()[0]), length);  
19                 m\_registers->bus\_write(data, addr, msk,   
20                                        &trans, m\_delay\_enabled);  
21             } else if(gp.is\_read()) {  
22                 msk = len2mask(length);  
23                 m\_registers->bus\_read(m\_rdata, addr, msk,   
24                                       &trans, m\_delay\_enabled);  
25                 gs::MData mdata(gs::GSDataType::dtype((uint8\_t \*)&m\_rdata,  
26                                 trans->getMBurstLength()));  
27                 trans->setSData(mdata);  
28             }  
29             gp.set\_response\_status(tlm::TLM\_OK\_RESPONSE);  
30         }  
31   
32         // tlm\_slave\_if implementation  
33         virtual void setAddress(uint64 base, uint64 high) {  
34             m\_base = base; m\_high = high;  
35         }  
36   
37         inline uint64 get\_base\_addr() { return m\_base; }  
38         inline uint64 get\_size() { return m\_high - m\_base;}  
39         inline void set\_delay() {}  
40   
41     protected:  
42         uint64 m\_base, m\_high;  
43         unsigned int m\_rdata;  
44 };

Figure 2 - AMBA Slave / blocking transport

## The Simple\_System Example

A good starting point for learning how the components of this library and the GreenSocs AMBAKit interact is the Simple\_System example. It is located in the library-level test directory (tests/simple\_system). The structure of the system is depicted in Figure 3.

Figure 3 - Simple\_System Test

The library components are drawn in blue, while the AMBAKit components are drawn in red. The system contains a testbench, which acts as a placeholder for the processor and provides stimuli to the system. The testbench connects to the Cache-Subsystem (mmu\_cache) through two TLM 2.0 sockets. The payload transported over these sockets contains optional extensions for address space selection (ASIs) and debugging. The mmu\_cache IP features an AHB master socket. The master socket is bound to the slave socket of a LT\_CT adapter. The system bus (ahb\_simple\_bus) and the AHB/APB bridge (ahb\_apb\_bridge) are part of the AMBAKit and model the communication with cycle timed accuracy. The memory controller (mctrl) is equipped with one AHB slave socket, one APB slave socket and TLM2 master sockets. The AMBA slaves are connected to the bus through CT\_LT adapters. The TLM2 masters are connected to four instances of the generic memory IP.

[Example will be extended throughout the course of the project!]

# Aeroflex Gaisler GRLIB MCTRL Memory Controller

## Functionality and Features

### Overview

The functionality of the TLM implementation of the MCTRL unit reproduces that of the Gaisler GRLIB VHDL implementation described in RD04. The controller reacts as a slave on the AHB bus and controls a memory subsystem comprising up to two memory buses and up to four types of memory. These are PROM, memory mapped I/O devices, SRAM, and SDRAM. The memory devices are addressed within three address spaces for ROM, local I/O, and RAM. The MCTRL unit forwards transaction objects between the AHB bus master and the attached memory devices.

The behavior of the MCTRL unit may be configured through setting its four configuration registers, which are attached to the APB bus and are summarized in Table 4. All registers have a width of 32 bits.

|  |  |
| --- | --- |
| APB Address Offset | Register |
| 0x00 | MCFG1 (PROM and I/O) |
| 0x04 | MCFG2 (RAM) |
| 0x08 | MCFG3 (SDRAM Refresh Period) |
| 0x0C | MCFG4 (Power Saving Configuration) |

Table 4 – MCTRL Registers

### Address Space

The address space is divided in the three parts of PROM, local I/O, and RAM. The division of the address space is static and cannot be modified after initialization of the MCTRL unit. In the VHDL implementation, the different parts of the address space are calculated from generics, which are implemented as constructor parameters in the TLM module. These constructor parameters will be called generics throughout this document.

The PROM address space is deduced from the generics romaddr and rommask, which define the start address and the size of the PROM address space. The romaddr generic is written to the 12 bit-wide ADDR field of the GRLIB PnP BAR0 register of the MCTRL unit and the rommask generic is written to the 12 bit-wide Mask field of the GRLIB PnP BAR0 register. The bit mask represents the 12 most significant bits of the memory address. As the address space is byte-addressable and the address width is 32 bit, the 12 MSBs can mask the address space with a resolution of 2^(32-12) bytes, i.e. 1 MByte. As address bits are masked at high level (logic 1), a higher value of the rommask generic will reduce the size of the address space. In other words, the mask represents how much of the address space is not allocated to the actual PROM.

The PROM address space covers

(2^12 – rommask) MByte = 4096 – rommask MByte,

which are divided into two PROM banks of equal size.

The local I/O address space is calculated similarly from the ioaddr and iomask generics. However, a subdivision into memory banks is not supported for local I/O.

The RAM address space calculation operates similar to the PROM address space calculation, but is based on the ramaddr and rammask generics. The subdivision of the RAM address space depends on the settings made in the MCFG2 register. The register provides the fields ‘SDRAM enable’ and ‘SRAM disable’ defining the presence of SRAM only, SDRAM only, or both. If the SDRAM enable bit is low, the SRAM disable bit takes no effect.

According to the organization of the RAM address space with respect to the number of banks, bank locations, bank sizes, and – in case of SDRAM – row and column address bits the GRIP user manual (RD04) is not always clear (see annex A.1). Hence, the address space organization has been implemented as a consistent scheme closest possible to the structure probably intended to be described in RD04. For the default size of 1 GByte of RAM address space, an example of the bank sizes for each configuration is given in Figure 4.

Figure 5 – RAM address space

The default configuration is the SRAM only configuration, Config 1. The entire RAM address space can be taken up by up to five SRAM banks. The number of SRAM banks is determined by the generic ‘srbanks’, the default value being 4. Banks 1-4 are always located in the lower half of the RAM address space. Their size is scalable between 8 KByte – 256 MByte and is determined by the ‘RAM BANK SIZE’ field of the MCFG2 register. If the bank size exceeds 128 MByte, the number of banks must be reduced or the size of the address space must be increased. In the SRAM only configuration, a fifth bank can be attached to take up the upper half of the RAM address space.

In the second configuration, Config 2, SRAM and SDRAM are attached to the MCTRL device. In this case, the lower half of the RAM address space is taken up by up to 4 SRAM banks. SRAM bank5 cannot be present, because two SDRAM banks take up the upper half of the RAM address space. The size of the SDRAM banks is scalable between 4 MByte – 512 MByte, according to the SDRAM BANKSZ field of the MCFG2 register. If the SDRAM bank size exceeds 256 MByte, i.e. if the SDRAM bank size is set to 512MByte, the RAM address space needs to be extended to the size of 2GByte to fit the SDRAM in the upper half of the RAM address space. As this will also extend the SRAM address space to 1GByte giving room for the maximum number of four SRAM banks of the maximum supported size of 256 MByte, a size of 2GByte represents the maximum sensible RAM address space. This would be represented by rammask = 0x800.

In the SDRAM only configuration, the SDRAM banks are mapped into the lower half of the RAM address space. If the SDRAM bank size is set to 512MByte, the RAM address space needs to be extended to the size of 2GByte. The upper half remains reserved and unused.

In any configuration, the initial bank sizes are calculated to be the maximum possible size, which can be deduced from address space size and number of banks.

It is possible to switch between the three configurations shown in Figure 4 dynamically by changing the according bits of the MCFG2 register. The MCTRL unit will react by recalculating the start and end addresses of the RAM banks. As only the address decoding will change, the contents of the memories remain unchanged. However, the bus master must take care to read from the correct memory banks after having caused a reorganization of the RAM address space. The bus master also has to take care of not exceeding the RAM address space when changing the SRAM or SDRAM bank size. If, for example, the RAM address space is 1GByte and the size of four SRAM banks is dynamically switched from 128 MByte to 256 GByte, the SRAM banks will take up the SDRAM address space, causing an overlap of SRAM and SDRAM device addresses. Due to the SystemC code structure, any access to SDRAM would then be redirected to SRAM causing system malfunction.

Remark:

Although dynamic reorganization of the address space regarding attached devices and bank sizes is supported, a practical use for a hardware system seems to be hard to identify. The functionality has been implemented, because the according fields in the configuration register aren’t flagged ‘read only’. However, it is recommended to keep the address ranges static.

Remark:

In addition to rommask and rammask, two generics, romasel and sdrasel, can be used to determine the PROM and RAM address space sizes in the VHDL implementation. Both generics must display an address space size equal to the according address mask generics to guarantee correct operation of the MCTRL unit. For the purpose of a reduction of error-proneness, the romasel and sdrasel generics have been removed from the TLM implementation.

### Memory Access

The memory access of the TLM MCTRL unit is handled in accordance with the type of memory that has to be accessed. The type of memory is determined by decoding the address given by the bus master, i.e. by analyzing the transaction payload. The ‘streaming width’ field of the payload is then eventually modified to one, two, or eight byte, before the payload is forwarded to the memory device.

The delay of a transaction is always fully modeled in the MCTRL unit, which holds information about all timing parameters involved. The timing parameters are given in the configuration registers. Additional delay information can be deduced from the streaming width and data length in case of burst transactions. All delay values are calculated as multiples of the bus clock period. For each memory access, the MCTRL unit adds a decoding delay of one bus cycle.

#### PROM Access

In case of PROM, write access needs to be explicitly allowed by setting the PWEN bit of the MCFG1 register. In case of disallowed write accesses, the MCTRL unit will abort the transaction and issue a TLM\_COMMAND\_ERROR\_RESPONSE.

A read access to PROM memory takes 4 bus cycles plus 0 – 15 wait states. A write access to PROM memory takes 3 bus cycles plus 0 – 15 wait states. The wait states can be configured via the PROM READ WS and PROM WRITE WS fields of the MCFG1 register.

A PROM write access can have a streaming width of 32, 16, or 8 bits. The access mode is set in the PROM WIDTH field of the MCFG1 register. If the PROM WIDTH field is set to 16 or 8 bits, a read access to the PROM will nevertheless result in retrieving a full 32 bit word, which will be transmitted in a burst of two half-words or four single bytes, adding a delay of two bus cycles (data1 and data2) in 16 bit mode or six bus cycles (3x data1 and 3x data2) in 8 bit mode.

#### Local I/O Access

The local I/O area supports access to 32 bit words, 16 bit half-words, and singe bytes. A read access takes 4 bus cycles (lead-in, data1, data2, lead-out) and a write access takes 3 bus cycles (lead-in, data, lead-out). For both, read and write operations, the VHDL implementation provides a dynamic bus ready signaling mechanism, which can induce an arbitrary number of wait states. As these arbitrary wait states model the latency of the attached I/O device, it is the task of the attached I/O device to model this delay and add it to the delay parameter of the TLM transport function. The MCTRL unit will observe the delay parameter and add its value to the overall transaction delay.

#### SRAM Access

The access to SRAM is similar to the PROM access, the difference being the number of wait states. For a read access, the number of wait states can be set via the RAM READ WS field of the MCFG2 register. Read accesses to SRAM bank5 and write accesses to SRAM support dynamic wait states in the VHDL model. Similar to the dynamic bus-ready-signaling in the I/O area, it is the task of the TLM memory device to add this delay to the delay variable of the TLM transaction.

#### SDRAM Access

The SDRAM banks can be accessed over a separate bus, if the sepbus generic is set to 1. The separate bus can have a width of 32 bit or 64 bit as indicated by the D64 field of the MCFG2 register.

In the RTL model, the SDRAM device is controlled by SDRAM commands. An ACTIVATE command is used to open a row, while a PRECHARGE command closes the row. While a row is open, READ or WRITE access to this row is possible.

A read access is always performed as a page burst access. As a burst access can be interrupted issuing a precharge command, it is possible to read an arbitrary number of data words. In the TLM model, the data length field of the generic payload can hence be set to any multiple of the SDRAM word length. The delay will be calculated for opening the row, sending one data word each clock cycle, and closing the row again. If the requested sequence of words starts at the end of a row and ends in the next row, the time for opening and closing the second row will be added.

The time required for opening a row is determined by the TCAS field of the MCFG2 register. If the TCAS field is changed, the memory device needs to take notice of this change. It will be reconfigured by MCTRL sending a LOAD MODE REGISTER (LMR) command. In the TLM model, the MCTRL unit models the timing of each transaction and expects the memory model to behave correctly, i.e. an LMR command would not have any functional effect. Hence, the LMR command is not issued, but its delay is modeled by adding it to the next transaction.

A write access to SDRAM is always performed as a single word write, i.e. burst mode is not supported. A requested write burst from the bus will be transformed into a burst of writes.

To retain data in memory, refresh cycles are required. The MCTRL unit only supports devices capable of AUTO REFRESH, i.e. MCTRL only needs to periodically trigger the refresh, which is then organized by the memory internally. In the TLM implementation, the refresh has no functional effect, but influences the overall operational speed of the memory device. The model keeps track of the refresh period and locks the SDRAM for the duration of one refresh cycle after each refresh period. If an access to the SDRAM device is requested while SDRAM is locked, the transaction will be stalled for the rest of the refresh cycle. The other way round, a refresh can also be stalled by a transaction.

### SDRAM Modes of Operation

The MCTRL unit can configure the SDRAM device to operate in different modes. The availability of operation modes depends on the ‘mobile’ generic, which determines the support of mobile memory. Mobile memory is designed for mobile devices and supports several power saving options.

For mobile = 0, mobile memory is not supported. In this case the MS field of MCFG2 will be set to 0 during the initialization phase of the MCTRL unit. This disables any effect of the MCFG4 register, which defines the power saving options and states of mobile memory.

For mobile = 1, mobile memory is supported, but disabled by default. The MS field of the MCFG2 register is set and the ME field of the MCFG4 register is set to 0. All other fields of the MCFG4 register cannot take effect, as long as the ME field is disabled.

For mobile = 2, mobile memory is supported and enabled by default.

For mobile = 3, mobile memory cannot be disabled, i.e. the ME field of MCFG4 becomes read only.

If mobile memory is enabled, the SDRAM device supports the power saving modes, power down, self-refresh, partial array self refresh, and deep power down. The mode of operation is determined by the MCTRL unit and can be set in the PMODE field of MCFG4.

#### Normal Operation Mode

On system startup, the SDRAM device is initialized for normal operation mode. As the software memory model does not need any initialization sequence, the latter is modeled by just adding the according delay.

In normal operation mode, the memory access works as described in section 4.1.3.4. In case of a change of the operation mode, the memory has to be configured for this mode by issuing a LOAD EXTENDED MODE REGISTER (EMR) command. Like the LMR command, EMR does not have any functional effect, but only introduces the delay of one cycle plus tRP (as defined in the TRP field of MCFG2).

#### Power Down Mode

To enter power down mode, mobile memory must be enabled and the PMODE field of the MCFG4 register must be changed to “001”. In power down mode, the input and output buffers of the SDRAM device are deactivated after an idle period of 16 clock cycles. The buffers can be woken up within one clock cycle at any time, i.e. each memory access takes one additional bus clock cycle in power down mode.

As the memory device wakes up on every access, it will also wake up on AUTO REFRESH. Hence, the power down mode is left for at least 16 bus clock cycles after any refresh cycle.

Entirely leaving power down mode by changing the PMODE field of the MCFG4 register induces the delay of an EMR command.

#### Self-Refresh Mode

If the system is powered down, the data in mobile SDRAM can still be retained through sending the SDRAM device into self-refresh mode. Entering self-refresh mode is induced by setting the PMODE field of the MCFG4 register to “010” and induces the delay of an EMR command.

In self-refresh mode, the system is expected to be powered down, i.e. memory access is expected not to be requested. Therefore the MCTRL unit will issue a TLM\_ADDRESS\_ERROR\_RESPONSE, if access to an SDRAM device in self-refresh mode is attempted.

Leaving self-refresh mode will induce a delay of an EMR command plus TXSR as defined in the MCFG4 register plus an auto-refresh cycle as defined by the TRFC field in the MCFG2 register.

#### Partial Array Self-Refresh Mode

In self-refresh mode, it is possible to retain only parts of the data in memory by activating the partial array self-refresh mode. This mode is entered setting the three-bit-wide PASR field in the MCFG4 register to a value not equal to zero. The partial array can be defined as half, quarter, eighth, or sixteenth by setting the PASR field to 001, 010, 101, or 110 respectively. The partial array always refers to the lower fragment of the SDRAM address space.

In the TLM model, entering partial array self-refresh mode will immediately erase all parts of SDRAM, which are not refreshed.

#### Deep Power Down Mode

To enter deep power down mode, mobile memory must be enabled and the PMODE field of the MCFG4 register must be changed to “101”. In deep power down mode, the contents of the SDRAM are deleted immediately. Any access to an SDRAM device in deep power down mode will result in a TLM\_ADDRESS\_ERROR\_RESPONSE by the MCTRL unit.

Deep power down mode can be exited changing the PMODE field of MCFG4. Leaving this mode will launch an initialization sequence.

## Internal Structure

The MCTRL module is implemented as a single class, because there is no possibility of a modular implementation that would obviously increase the transparency of the code. The monolithic implementation is expected to compile and simulate slightly faster than a modular implementation. An overview of the module, including its interface, reset mechanism, dynamic configuration, and operation, is given in Figure 6.

Figure 6 – Structure of the MCTRL TLM

According to the BSSC2000(1) coding standard, the definition and the implementation of the module are stored in two separate files, mctrl.h and mctrl.cpp, respectively. The subsequent sections describe the contents of these files and explain the components shown in Figure 6.

### The mctrl.h File

The ‘mctrl.h’ file contains the module class definition.

#### Parameterization of the module

The parameterization options, implemented as generics in the VHDL model, are realized as constructor parameters of the class. This makes the module parametrizable during instantiation. Details on the parameters are given in section 4.3.

#### Configuration of the module

The MCTRL unit is configurable through its configuration registers. The configuration registers, which are accessible through the APB bus, are modeled and accessed through the comfortable mechanisms provided by GreenReg. To ensure GreenReg compatibility, the Mctrl module needs to be a child module of a GreenReg Device. A gr\_device is a top-level encapsulation for a complete functional unit and provides containment structures for other GreenReg elements, e.g. registers. Thus, the Mctrl class inherits the gr\_device class.

The ‘mctrl.h’ file contains const variables defining register addresses and bit masks. These definitions are made for programming convenience.

The write masks of the registers can be used to ensure that only permitted bits are set when writing to a register. They can also be applied for reading specific fields of a register masking all other bits.

The default masks are written to the registers at system initialization and in the system-reset function.

#### Communication with the module

A bus master can access the MCRTL unit through the AHB bus. For correct attachment to the AHB bus, the MCTRL unit also needs to inherit the amba\_slave\_base class. The get\_base\_addr and get\_size functions of this class are overloaded in the MCTRL class definition. These functions specify the address space dedicated to the MCTRL unit. Thus, the get\_base\_addr function returns the start address of the lowest memory and the get\_size function returns the size of the entire address space managed by the MCTRL unit.

#### Operation of the module

The Mctrl class definition contains the module interface and the function prototypes of constructor, destructor, callback functions, and pure C++ software routines. For reasons of simulation performance it is always good to avoid the usage of SystemC processes. Hence, the functionality of the MCTRL module has been modeled without any processes.

SystemC processes have to be registered with the SystemC simulation kernel using the SystemC macro, SC\_HAS\_PROCESS(). In a similar fashion, the callback functions, which are hooked to the registers built with GreenReg, are registered with the SystemC simulation kernel using the GreenControl macro, GC\_HAS\_CALLBACKS().

In addition, some class attributes are defined to keep track of the overall configuration and operation of the module:

* The **address space variables** define the borders of each memory bank attached to the device. These variables are required for the address decoding mechanism and to identify, which type of memory is accessed in the current transaction. The type of memory must be known, because the timing is modeled in the MCTRL unit and differs for each type of memory. The timing is modeled in the MCTRL unit and not in the memory itself, because all timing information is known in the MCTRL model and the attached memory model shall be kept generic.
* A **pmode variable** is used to indicate the current operation mode of the SDRAM device. The operation mode will affect the timing of a transaction and therefore needs to be checked for each transaction. Hence, the pmode variable can be interpreted to represent a part of a state machine controlling the SDRAM device.
* A **callback\_delay variable** saves any delay that occurs during the execution of callback functions. To save implementing an SC\_THREAD to model this delay, it is added to the delay of the next transaction.
* A **start\_idle variable** stores the sc\_time\_stamp at which SDRAM enters idle state. If, in power down mode, the start\_idle time lies more than 16 clock cycles in the past, an SDRAM access will take an additional bus clock cycle for waking up from power down state.
* A **next\_refresh variable** stores the point of time at which the next SDRAM refresh cycle is scheduled to start. The variable is updated dynamically. The refresh mechanism does not have any impact on the functionality, but it may influence the timing of a transaction. This may happen in case the transaction starts, while a refresh is active. In that case the transaction will be stalled and started after the end of the refresh cycle.
* A **trfc variable** stores the number of cycles a refresh will take. It can dynamically change by writing to the SDRAM TRFC field of the MCFG2 register. The value is stored to a variable, because it has to be checked for each SDRAM transaction. A variable is much faster than reading the value from the configuration register container each time.
* A **refresh\_stall variable** stores the amount of simulation time for which a refresh has to be stalled. A stall can be necessary if an SDRAM access is currently active, while the start of a refresh cycle is scheduled. The refresh will then be scheduled right after this transaction, i.e. the refresh\_stall will be added to the next\_refresh variable. After a stalled refresh, the next\_refresh variable will be updated adding a refresh period and subtracting the value of the refresh\_stall variable. This keeps the refresh period constant on average.

### The mctrl.tpp File

The ‘mctrl.tpp’ file implements all the member functions of the Mctrl class, including constructor, destructor, and the TLM transport functions.

#### Construction and Initialization of the module

The construction and the initial configuration of the MCTRL unit is carried out in three places.

1. The **constructor** sets the generics and configures the PnP settings, the gr\_device and the bus interface. In addition, the constructor builds a GreenReg register container ‘r’, in which it implements all the registers listed in Table 4. The register container is a C++ class implemented in the GreenReg libraries that provides memory management and interface functions. Within this register container, the GreenReg registers are instantiated and initialized with their default values during instantiation of the MCTRL unit. The default values of the registers are stored as constants in the class definition in the mctrl.h file.
2. The **built-in SystemC function end\_of\_elaboration()** is used for hooking the callback functions to the according registers. This is done after elaboration, when all registers and functions are known to the compiler. The callback functions need to be triggered, when certain bits of the control registers change. To register the callbacks with these bits, specific bit accessors for these bits must be created before registering the sensitivity. This is done with the member function br.create() of the register container. When the bit accessors are defined, the callbacks can be registered by subsequently calling the GreenReg macros GR\_FUNCTION and GR\_SENSITIVE.
3. The **reset\_mctrl()** function is called at the end of the end\_of\_elaboration() function to update and finalize the initial configuration. Although hard-coded default values are already present in the configuration registers, these are overrule by the generics and might therefore be updated. Especially the permission of SDRAM and mobile SDRAM has to be granted or denied. In addition all delay variables are reset to zero, the length of the refresh cycle is read from the registers, and the address space variables are calculated from the generics.

These tasks are performed in a separate reset function, not in the end\_of\_elaboration() function, because the reset\_mctrl() function is also registered as a callback to the reset input signal of the module. That way, the common practice of initialization through an initial reset is applied for the MCTRL unit.

#### Configuration of the module

After initialization, some of the settings in the configuration of the MCTRL unit can be changed dynamically. The dynamic configuration is generally performed by writing to the configuration registers. When the configuration registers change, callback functions react to these changes and perform the necessary configuration operations. The following callback functions are implemented:

* The **configure\_sdram callback function** reacts to the TCAS field of the MCFG2 register and the DS, TCSR, and PASR fields of the MCFG4 register, all of which require an immediate LMR or EMR command. The LMR and EMR commands are assumed to be issued at the same time as the change of the above-mentioned fields. The operation of the MCTRL unit is adapted to the changed register values and the memory model is assumed to operate accordingly after the delay induced by the LMR or EMR command. This delay is added to the callback\_delay variable.
* The **launch\_sdram\_command callback function** reacts to the SDRAM\_COMMAND field of the MCGF2 register. According to the field value being set to 01, 10, or 11, a PRECHARGE, AUTO-REFRESH, or LMR/EMR command can be forced. As LMR/EMR are assumed to be issued when required and only when required, these commands are ignored. AUTO-REFRESH and PRECHARGE are modeled by adding their delay to the callback\_delay variable in the LT model. In any case the SDRAM\_COMMAND field is cleared by this callback.
* The **erase\_sdram callback function** reacts to a change of the mode of operation of the SDRAM device. If SDRAM is sent to partial array self-refresh or deep power down mode, an according erase command is sent to the SDRAM device. As this command is not provided by the generic payload, the ext\_erase extension is appended to the transaction payload. The memory model checks for this extension and calls a software function to erase the according parts of the SDRAM memory area. The memory area to be erased is deduced from the address and data fields of the generic payload, where the address field contains the start address and the data field contains the end address.
* The **sram\_disable,**
* **sdram\_enable,**
* **sram\_change\_bank\_size and**
* **sdram\_change\_bank\_size callback functions** react to changes of the MCFG2 register fields SI, SE, RAM\_BANK\_SIZE, and SDRAM\_BANKSZ respectively. All the functions perform a complete recalculation of the ram address space variables. Several of these functions need to recalculate the SRAM bank address variables. To prevent the multiplication of this lengthy code, it has been outsourced into the sram\_calculate\_bank\_addresses function.

#### Operation of the module

According to the configuration and operating mode, the b\_transport function reacts to incoming transactions from the bus master. First of all, the address field of the generic payload is analyzed and compared to the bank address variables to determine the memory type that has to be accessed. If the according memory is configured to operate in any access mode other than 32 bit, the streaming width of the generic payload is adapted to this setting. The streaming width must be reset to 4 Byte by the memory device.

In the next step, the command field is analyzed to calculate the correct delay for a read or write transaction. Finally, the delay is added and the transaction payload is forwarded to the memory using the according socket. In case of access failure, e.g. write access to read-only PROM, the transaction payload is not forwarded, an error response is given, and only the decoding delay is added to the delay variable.

## Parametrization Options

In the VHDL implementation, the parameterization is fully controlled by generics, which are supported as constructor parameters in the SystemC module. The parameters are summarized in Table 5. The shadowed generics have been removed in the TLM implementation.

|  |  |  |  |
| --- | --- | --- | --- |
| **Parameter** | **Function** | **Allowed Range** | **Default** |
| hindex | AHB slave index | 0 to  NAHBSLV–1 | 0 |
| pindex | APB slave index | 0 to  NAPBSLV–1 | 0 |
| romaddr | ADDR field of BAR0 defining PROM address space. | 0 – 0xFFF | 0x000 |
| rommask | MASK field of BAR0 defining PROM address space size. rommask = PROM address space size in MByte | 0 – 0xFFF | 0xE00 |
| ioaddr | similar to romaddr | 0 – 0xFFF | 0x200 |
| iomask | similar to rommask | 0 – 0xFFF | 0xE00 |
| ramaddr | similar to romaddr | 0 – 0xFFF | 0x400 |
| rammask | similar to rommask | 0 – 0xFFF | 0xC00 |
| paddr | ADDR field of the APB BAR configuration registers address space | 0 – 0xFFF | 0x000 |
| pmask | MASK field of the APB BAR configuration registers address space | 0 – 0xFFF | 0xFFF |
| wprot | RAM write protection | 0 – 1 | 0 |
| invclk | Inverted clock is used for SDRAM | 0 – 1 | 0 |
| fast | Enable fast SDRAM address decoding | 0 – 1 | 0 |
| romasel | log2(PROM address space size) – 1 | 0 – 31 | 28 |
| sdrasel | log2(RAM address space size) – 1 | 0 – 31 | 29 |
| srbanks | Number of SRAM banks | 0 – 5 | 4 |
| ram8 | Enable 8 bit PROM and SRAM access | 0 – 1 | 0 |
| ram16 | Enable 16 bit PROM and SRAM access | 0 – 1 | 0 |
| sden | Enable SDRAM controller | 0 – 1 | 0 |
| sepbus | SDRAM is located on separate bus | 0 – 1 | 1 |
| sdbits | 32 or 64 bit SDRAM data bus | 24, 64 | 32 |
| oepol | Select polarity of drive signals for data pads (0 = active low, 1 = active high) | 0 – 1 | 0 |
| mobile | Enable Mobile SDRAM support  0: Mobile SDR is not supported  1: Mobile SDR is supported but disabled  2: Mobile SDR is supported and default  3: Mobile SDR support only | 0 – 3 | 0 |
|  |  |  |  |

Table 5 – MCTRL Template Parameters

## Interface

The interface of the MCTRL unit comprises the means to APB bus communication, AHB bus communication, and communication with the memory devices.

### APB Bus Communication

The MCTRL configuration registers MCFG1 – MCFG4 listed in Table 4 can be accessed via a TLM socket. As the callbacks described in section 4.2.3 are hooked to these registers, they must be part of a GR\_DEVICE and are addressed via a GreenReg compatible socket. The base address and the size of the register file can be calculated from the paddr and pmask generics.

### AHB Bus Communication

All requests of memory accesses are received from the AHB. An AHB slave socket of the MCTRL unit listens at the entire memory address space of the AHB. A generic payload received by this socket is prepared for further use and forwarded to the memory device indicated by the address field of the payload.

### Memory Device Interface

The MCTRL unit provides four TLM simple initiator sockets, one for each memory device. The sockets are named mctrl\_rom, mctrl\_io, mctrl\_sram, and mctrl\_sdram. According to the address field of a generic payload received on the AHB socket, the transaction is forwarded over the related initiator socket.

For the SDRAM communication, a payload extension is defined in the MCTRL unit. The extension indicated that a specific command, namely erase\_sdram, has to be executed.

## Compilation Instructions

For the compilation of the MCTRL unit, a WAF wscript file is provided and integrated in the superordinate build mechanism of the TLM model library of the Hardware-Software SystemC Co-Simulation SoC Validation Platform project.

The libraries required for the compilation are:

 1 #include **<algorithm>**  
 2 #include **<iostream>**  
 3 #include **<boost/config.hpp>**  
 4 #include **<systemc.h>**  
 5 #include **<tlm.h>**  
 6 #include **<greenreg.h>**  
 7 #include **<greenreg\_ambasocket.h>**  
 8 #include **"greencontrol/all.h"**  
 9 #include **"tlm\_utils/simple\_initiator\_socket.h"**  
10 #include **"mctrlreg.h"**  
11 #include **"generic\_memory.h"**  
12 #include **"grlibdevice.h"**

## Example Instantiation

The following example shows how to instantiate the MCTRL TLM. The AHB and APB sockets are connected to a testbench that behaves like an AHB and APB master. The simple initiator sockets are connected to instances of the Generic\_memory module described in chapter 6.

 1 **int** sc\_main(**int** argc, **char**\*\* argv) {  
 2   //set generics  
 3   **const** **int** hindex = 0;  
 4   **const** **int** pindex = 0;  
 5   **const** **int** romaddr = 0;  
 6   **const** **int** rommask = 3584;  
 7   **const** **int** ioaddr = 512;  
 8   **const** **int** iomask = 3584;  
 9   **const** **int** ramaddr = 1024;  
10   **const** **int** rammask = 3072;  
11   **const** **int** paddr = 0;  
12   **const** **int** pmask = 4095;  
13   **const** **int** wprot = 0;  
14   **const** **int** srbanks = 4;  
15   **const** **int** ram8 = 0;  
16   **const** **int** ram16 = 0;  
17   **const** **int** sepbus = 0;  
18   **const** **int** sdbits = 32;  
19   **const** **int** mobile = 0;  
20   
21   //instantiate mctrl, generic memory, and testbench  
22   Mctrl mctrl\_inst0(**"mctrl\_inst0"**, hindex,  pindex,  romaddr, rommask, ioaddr, iomask,  
23                                    ramaddr, rammask, paddr,   pmask,   wprot,  
24                                    srbanks, ram8,    ram16,   sepbus, sdbits, mobile);  
25   Generic\_memory <**uint8\_t**>  generic\_memory\_rom(**"generic\_memory\_rom"**);  
26   Generic\_memory <**uint32\_t**> generic\_memory\_io(**"generic\_memory\_io"**);  
27   Generic\_memory <**uint8\_t**>  generic\_memory\_sram(**"generic\_memory\_sram"**);  
28   Generic\_memory <**uint32\_t**> generic\_memory\_sdram(**"generic\_memory\_sdram"**);  
29   Mctrl\_tb mctrl\_tb(**"mctrl\_tb"**, hindex,  pindex,  romaddr, rommask, ioaddr, iomask,  
30                                 ramaddr, rammask,  paddr,   pmask,   wprot,  
31                                 srbanks, ram8,     ram16, sepbus, sdbits, mobile);  
32   
33   //bus communication via amba sockets (TLM)  
34   mctrl\_tb.apb\_master\_sock(mctrl\_inst0.apb);  //config registers  
35   mctrl\_tb.ahb\_master\_sock(mctrl\_inst0.ahb);  //memory access  
36   
37   //memory communication via simple TLM sockets  
38   mctrl\_inst0.mctrl\_rom(generic\_memory\_rom.slave\_socket);  
39   mctrl\_inst0.mctrl\_io(generic\_memory\_io.slave\_socket);  
40   mctrl\_inst0.mctrl\_sram(generic\_memory\_sram.slave\_socket);  
41   mctrl\_inst0.mctrl\_sdram(generic\_memory\_sdram.slave\_socket);  
42   
43   sc\_core::sc\_start();  
44   **return** 0;  
45 }

# Memory Model

## Functionality and Features

The Generic\_memory model is not based on any reference design from the Gaisler GRLIB, but it was developed from scratch to suit the MCTRL unit described in chapter 3.

The model is generic in a sense that it can be any type of memory and does not know what kind of memory it is. The model is merely used to store data and does not model any delay. As any memory controller needs to know all the timing information of the attached memory device anyway, the delay can be added in the memory controller to keep the memory universally applicable.

The memory model supports two different word lengths of 32 bit or 8 bit, which can be determined by a template parameter. For each of the word lengths, a read function and a write function is provided. The read and write functions take a data pointer and a variable indicating the data length as arguments, so any amount of data can be read or written at any time.

As an additional feature, the memory model provides a function that can erase a specific region of the memory. This function can only be accessed through appending the ext\_erase extension to the transaction payload. The ext\_erase extension is implemented in the MCTRL unit.

## Internal Structure

The source code of the Generic memory model is split into two file, generic\_memory.h and generic\_memory.tpp.

### The generic\_memory.h File

The header file defines the class template of the memory model. It implements the simple target socket for communication with the MCTRL unit and defines the constructor and read, write, and erase function prototypes. According to the template parameter given at the time of instantiation, a map representing the memory with values of uint8\_t or uint32\_t is instantiated. (The map data type has initially been chosen for addressing reasons, but might be replaced by an array after a performance evaluation that is still pending.) In addition, a prototype of the TLM transport function is defined.

### The generic\_memory.tpp File

The generic\_memory.tpp is technically a header file that is included at the bottom of the generic\_memory.h file. This mechanism is chosen for enabling the separation of module definition and module implementation although the module is a template class.

The generic\_memory.tpp file implements the functions defined in the header file, including the constructor. The constructor names the socket and registers the b\_transport function with this socket.

The b\_transport function then receives any transaction object that is received by the simple target socket. The generic payload is analyzed and one of the read or write functions is called. As a special case, the erase extension is checked first.

The read or write function to be called depends on the template parameter given at instantiation. For an 8 bit map, the 8 bit read and write functions need to be used, for a 32 bit map the 32 bit function are required. Which function to use can partially be deduced from the generic payload and definitely determined by additionally checking the size of a map element. If the streaming width is 8 Byte, SDRAM is accessed and a 32 bit function has to be used. If the streaming width is 2 Byte or 1 Byte, an 8 Bit function is required. If the streaming width is 4 Byte, the size of a map element needs to be checked for definite determination. Read or write access can be distinguished checking the command field of the generic payload.

The read and write functions are trivial and do not need any further explanation.

## Parametrization Options

The element size of the map implementing the memory can be parameterized via a template parameter. Allowed element types are uint8\_t and uint32\_t. For any other data type, the error free operation of the memory is neither precluded nor guaranteed.

## Interface

The Generic\_memory model instantiates a TLM simple target socket that receives any transaction sent from the MCTRL unit. It understands the ext\_erase extension that is defined in the MCTRL unit.

## Compilation Instructions

The compilation of the Generic\_memory integrated in the compilation of the MCTRL test structure and the superordinate build mechanism of the TLM model library of the Hardware-Software SystemC Co-Simulation SoC Validation Platform project.

The libraries required for the compilation are:

1 #include **<map>**  
2 #include **<boost/config.hpp>**  
3 #include **<systemc.h>**  
4 #include **<tlm.h>**  
5 #include **<greenreg.h>**  
6 #include **<greenreg\_ambasocket.h>**  
7 #include **"greencontrol/all.h"**  
8 #include **"tlm\_utils/simple\_target\_socket.h"**

## Example Instantiation

For an example instantiation, please refer to the MCTRL example in section 3.6.

# CACHE Sub-systeM

## Functionality and Features

### Overview

The Cache Sub-System implements the functionality of the Gaisler GRLIB Harvard L1 Cache and the Sparc V8 Reference MMU. It is therefore related to the *mmu\_cache* entity of the GRLIB hardware library.

The structure of the Cache Sub-System is depicted in Figure 5. The top-level class *mmu\_cache* provides two TLM2 *simple\_target\_sockets* (icio, dcio) for communication with the CPU and one TLM2 GreenSocs *amba\_master\_socket* for the connection of an AMBA AHB bus. All the sub-components, such as the mmu, the caches and the localrams are implemented in plain C++ and can be accessed through their member functions (APIs).

Equivalent to the hardware model the caches can be direct mapped, 2-way, 3-way or 4-way set associative. For multi-set configurations LRU, LRR and pseudo-random replacement are supported. The size of the cache sets can be beween 1 and 64 kbytes, with up to 32 bytes per line. The caches can be flushed, frozen or locked on a line-by-line basis. The write policy of the data cache is write through with no-allocate on write miss.

The localrams can be optionally enabled. They provide 0-waitstate access to up to 512 kbyte of memory, starting from a segment address, which can be freely chosen.

The MMU can also be optionally enabled. The MMU page size is 4, 8, 16 or 32 kbyte. The TLBs can hold between 2 and 32 page descriptors. In case of a page miss a 3-level table walk is carried out on main memory. Similarily to the localrams, instantiation of the mmu is done by late binding depending on configuration parameters. The caches connect to the mmu through *tlb\_adaptor* objects. The *tlb\_adaptors* present a unified memory interface towards the caches (*mem\_if*). The same memory interface is used to provide access to the AHB master socket on top-level. This way it can be dynamically decided whether a request from one of the caches shall be forwarded to a shared or common TLB (virtual addressing), or directly go to the AHB interface (physical addressing).

Figure 7 - Structure of Cache Sub-System

### Address Space Identifiers (ASI)

SPARC processors can generate an 8-bit address space identifier (ASI), to provide access to up to 256 separate 32-bit address spaces. These ASIs are heavily used to control the cache sub-system. A list of the ASIs supported by the TLM model is given in Table 4.

|  |  |  |
| --- | --- | --- |
| ASI | Address | Usage |
| 0x01 | any | Forced cache miss |
| 0x02 | 0x00 | Cache control register |
|  | 0x04 | Reserved |
|  | 0x08 | Instruction cache configuration register |
|  | 0x0c | Data cache configuration register |
|  | *0xff* | *Trigger debug output\** |
| 0x08,0x09,0x0A,0x0B | any | Normal cache access |
| 0x0c | see 5.1.4 | Access instruction cache tags |
| 0x0d | - “ - | Access instruction cache data |
| 0x0e | - “ - | Access data cache tags |
| 0x0f | - “ - | Access data cache data |
| 0x10 | - “ - | Flush instruction cache |
| 0x11 | - “ - | Flush data cache |
| 0x19 | 0x000 | MMU control register |
|  | 0x100 | MMU Context pointer register |
|  | 0x200 | MMU Context register |
|  | 0x300 | MMU Fault status register |
|  | 0x400 | MMU Fault address register |

Table 6 - Supported ASIs

ASIs are emitted by the data interface of the processor. For this purpose an optional payload extension has been linked to the data cache payload (*dcio\_payload\_extensions*). For more information about payload extensions see section 5.1.5.

The ASIs are decoded in the transport function of the dcache in/out socket (dcio), which is located in the top-level module (*mmu\_cache)*. The decoder maps the ASIs to API functions of the corresponding sub-components (caches, mmu). The API functions are described in section 5.4.

### System and Control Registers

The cache sub-system is controlled by a set of system registers, which can be accessed using ASIs.

Three of the mentioned registers are dedicated to the caches (ASI 0x02). The Cache Control Register (CCR - Table 5) effects both, data and instruction cache. Therefore it is implemented on top-level (*mmu\_cache*). Moreover, each of the caches has its own private Configuration Register (CR - Table 6). The CRs are read-only. At system boot they can be accessed to determine structure and size of the caches.

|  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 31 24 | 23 | 22 | 21 | 20 17 | 16 | 15 | 14 | 13 6 | 5 | 4 | 3 2 | 1 0 |
|  | DS | FD | FI |  | IB | IP | DP |  | DF | IF | DCS | ICS |

Table 7 - CACHE CONTROL REGISTER

[DS] Data cache snoop enable

If set, will enable data cache snooping (todo).

[FD] Flush data cache

If set, will flush the instruction cache. Always reads zero.

[FI] Flush instruction cache

If set, will flush the instruction cache. Always reads zero.

[IB] Instruction burst fetch

This bit enables burst fill during instruction fetch (todo).

[IP] Instruction cache flush pending (not supported)

[DP] Data cache freeze on interrupt (not supported)

[IF] Instruction cache freeze on interrupt (not supported)

[DCS] Data cache state

Indicates the current data cache state according to the following:

X0 = disable, 01 = frozen, 11 = enabled.

[ICS] Instruction cache state

Indicates the current instruction cache state according to the following:

X0 = disabled, 01 = frozen, 11 = enabled.

|  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 31 | 30 | 29 28 | 27 | 26 24 | 23 20 | 19 | 18 16 | 15 12 | 11 4 | 3 | 2 0 |
| CL |  | REPL | SN | SETS | SSIZE | LR | LSIZE | LRSIZE | LRSTART | M |  |

Table 8 - ICACHE & DCACHE Configuration Register

[CL] Cache looking

If set, cache locking is implemented

[REPL] Cache replacement policy

00 = non (direct mapped), 01 = least recently used (LRU), 10 = least recently used (LRR), 11 = random

[SN] Data cache snooping

Set if snooping is implemented

[SETS] Number of sets in the cache

000 = direct mapped, 001 = 2-way associative, 010 = 3-way associative, 011 = 4-way associative

[SSIZE] Set size

Indicates the size (Kbytes) of each cache set (Size = 2^SSIZE).

[LR] Local RAM

Set if local scratchpad is present.

[LSIZE] Line size

Indicates the size (words) of each cache line (Line size = 2^LSIZE).

[LRSIZE] Local RAM size

Indicates the size (Kbytes) of the implemented scratchpad RAM   
 (Size = 2^LRSIZE).

[LRSTART] Local RAM start address

Indicates the 8 most significant bits of the local RAM start address.

[M] MMU present

Set if MMU is present

The MMU is controlled by five 32-bit registers, which can be accessed through ASI 0x19 (Table 7). All those registers are implemented within the MMU.

|  |  |  |  |
| --- | --- | --- | --- |
| *MMU Control Register* | 31 1 | | 0 |
| not used | | E |
| *Context Pointer Register* | 31 2 |  | |
| Context Table Pointer |  | |
| *Context Register* | 31 0 | | |
| Context Number | | |
| *Fault Status Register* | 31 0 | | |
| Not implemented yet | | |
| *Fault Address Register* | 31 0 | | |
| Fault address (not implemented yet) | | |

Table 9 - MMU Control Registers

From the MMU Control Register only one bit is implemented in the TLM model. It is used to enable and disable the MMU.

The Context Pointer Register points to the Context Table in main memory. It forms bit 35 – 6 of the physical address. The table is indexed by the contents of the Context Register.

The Context Register contains the number of the current context and defines which of the possible address spaces is used for address translation.

The Fault Status Register provides information on exceptions (faults) issued by the MMU. It is currently not implemented and reads as 0.

The Fault Address Register contains the virtual memory address of the fault recorded in the Fault Status Register. It is currently not implemented and reads as 0.

The full set of options concerning the MMU Control Registers is described in the Sparc V8 Reference Manual [RD06].

### Diagnostic Access

Most of the internal data structures of Cache and MMU can be accessed for diagnostic purpose through dedicated ASIs.

The Tag and Data RAM of instruction and data cache can be read and written using ASI 0x0C – 0x0F (see section 5.1.2). Addressing and alignment of data are equivalent to the mechanism described in section 55.5.2. of RD05.

ADDRESS = WAY & LINE & DATA & “00”

### Payload Extensions

The communication between the processor and the Cache Sub-System requires additional information to be attached to the TLM2 generic payload. The extensions are modelled in two classes:

icio\_payload\_extension.h/cpp optional extensions for instruction cache socket

dcio\_payload\_extension.h/cpp optional extensions for data cache socket

Both classes declare a debug extension, which is modeled as a 32bit unsigned integer. The usage of the debug extension is explained in 5.1.6.

The dcio extensions additionally contain an ASI attribute, which is also modeled as a 32 bit unsigned integer. Purpose and usage of address space identifiers has been explained in 5.1.2.

### Debug Mechanism

The cache sub-system is a rather complex model. Hence, for assertion based verification, it is not sufficient to simply check whether the data response on a request is correct. It is also important to know in which way the result was produced (e.g. cache hit/miss).

For this purpose a 32bit unsigned integer extension has been attached to the generic payload of the icio/dcio sockets. Moreover, a set of macros has been defined in order to ease their handling. The encoding of the debug extension is shown in Table 8. The macro definitions can be found in the defines.h files of the mmu\_cache library.

|  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 31 22 | 21 | 20 16 | 15 | 14 | 13 | 12 | 11 4 | 3 2 | 1 0 |
| Reserved | MMUS | TLBN | Reserved | FM | CB | SP | Reserved | CST | CS |

Table 10 - Debug Extension

[MMUS| MMU state

0 – TLB hit; 1- TLB miss

[TLBN] TLB number

for TLB hit – number of the TLB that delivered the hit

for TLB miss – number of the TLB that was refilled by the miss

[FM] Frozen miss

If the cache is frozen, no new lines are allocated on a read miss. However, unvalid data will be replaced as long the tag of the line does not change. In case the results of a read miss is not cached, the FM bit is switched on.

[CB] Cache bypass

Is set to 1, if cache bypass was used (cache disabled in CCR)

[SP] Scratchpad

Is set to 1, if the request was answered by the local scratchpad RAM

[CST] Cache State

00 – read hit, 01 – read miss, 10 – write hit, 11 – write miss

[CS] Cache Set

for read/write hit – number of set which produced the hit

for read miss – number of set refilled by miss processing

for write miss – 0b00 (no allocate on write miss)

The Debug Extension is extensively used in all testbenches of the Cache Sub-System. The mechanism is straight forward as shown below:

dwrite(addr, data, length, asi, flush, flushl, lock, debug);

assert(CACHEWRITEMISS\_CHECK(\*debug));

The dwrite method is a testbench function, which sends a write transaction to the data socket (dcio) of the cache. The last argument of the function is an unsigned int pointer (debug). During execution of the transaction the components of the Cache Sub-System update the pointed debug field. Depending on the state of the system different bits are set. With this information the expected behavior can be checked after return of the transaction.

In the example above the CACHEWRITEMISS\_CHECK macro is connected with an assertion to make sure that the transaction was a write miss.

## Internal Structure

This section briefly describes the internal structure of the Cache-Subsystem SystemC IP. Detailed descriptions as well as inheritance and collaboration diagrams can be found in the doxygen documentation.

The Cache-Subsystem IP is formed by multiple source files, which can be found in the models/mmu\_cache/lib directory.

### The defines.h file

This file contains all globally relevant macro and data type definitions. It defines the structure of the cacheline (t\_cache\_line), the data cache entries (t\_cache\_data), the cache tags (t\_cache\_tag), the mmu page table entries (t\_PTE\_context) and the virtual address tag (t\_VAT).

Moreover, the file contains macros for unified formatting of debug output (DUMP), as well as SET and CHECK methods for handling of the debug payload extension described in section 5.1.6.

### The payload\_extension files

The *mmu\_cache* model features two *tlm::simple\_target\_sockets* for connection of the cpu instruction and data ports. These connections implement a simple point-to-point communication, which can be realized, widely relying on TLM2 generic payload. Only a few optional payload extensions are required.

The payload extensions for the instruction cache input/output socket (icio) are implemented by the files icio\_payload\_extensions.h/cpp.

// extensions

// ----------

/// flush instruction cache

unsigned int flush;

/// flush instruction cache line

unsigned int flushl;

/// line offset in cache flush

unsigned int fline;

/// debug information  
unsigned int \* debug;

The payload extensions for the data cache input/output socket (dcio) are implemented by the files dcio\_payload\_extensions.h/cpp.

// extensions

// ----------

/// address space identifier

unsigned int asi;

/// flush data cache

unsigned int flush;

/// flush data cache line

unsigned int flushl;

/// lock cache line

unsigned int lock;

/// debug information

unsigned int \* debug;

### The mem\_if.h file

The *mem\_if.h* file defines a generic memory interface that is directly or indirectly implemented by almost all the classes of the Cache Sub-System (Figure 6).

The *class mem\_if* is an abstract class with two virtual member functions:

virtual void mem\_write(unsigned int addr, unsigned char \* data, unsigned int length, sc\_core::sc\_time \* t, unsigned int \* debug) {};

virtual void mem\_read(unsigned int addr, unsigned char \* data, unsigned int length, sc\_core::sc\_time \* t, unsigned int \* debug) {};

The same interface is used to e.g. access the ahb master interface in class *mmu\_cache* or the *tlb\_adapters* of the *mmu*. This way cache misses can be easily redirected depending on configuration options (late binding).

![Bildschirmfoto 2010-08-27 um 11.50.17.png](data:image/png;base64,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)

Figure 8 - Generic Memory Interface / Dependencies

### The mmu\_cache\_if.h file

The *mmu\_cache\_if* class extends the *mem\_if* class by member functions that provide access to the Cache Control Register. The Cache Control Register is implemented at the top-level of class *mmu\_cache.* Many sub-components, such as the caches and the mmu need to read/write the ahb master interface of *mmu\_cache* or execute checks on the Cache Control Register. These components expect a pointer of type *mmu\_cache\_if* as a constructor argument.

### The mmu\_cache.h/cpp files

The files declare and implement the top-level class of the Cache Sub-System. The class *mmu\_cache* inherits the abstract *mmu\_cache\_if* interface and holds a set of pointers to various sub-components:

*ivectorcache\* icache - instruction cache pointer*

*dvectorcache\* dcache - data cache pointer*

*mmu\* m\_mmu - memory management unit*

*localram\* ilocalram - instruction scratchpad*

*localram\* dlocalram - data scratchpad*

The sub-components are dynamically created in the constructor of the class. The instantiation depends on parametrization options (see 5.3). In case a certain module is not required, a NULL pointer will be assigned. If the mmu is enabled, the caches will use the memory interfaces (mem\_if) of the instruction and data tlb adapters for miss processing. Otherwise they are directly connect to the memory interface of *mmu\_cache*.

Next to the AHB master, class mmu\_cache contains two TLM2 slave sockets for connection to the processor (Table 9).

|  |  |  |
| --- | --- | --- |
| Name | Type | Description |
| icio | TLM2 / simple\_target\_socket (LT) | Instruction cache in/out |
| dcio | TLM2 / simple\_target\_socket (LT) | Data cache in/out |
| ahb\_master | GreenSocs / amba\_master\_socket (LT) | AHB bus master |

Table 11 - TLM Sockets Cache Sub-System

The class implements blocking transport functions for both TLM2 slave sockets. The transport functions decode the payload and translate the request into function calls to the sub-component APIs.

The transport function of the icio instruction cache socket is very compact. After extracting the payload, the *tlm\_command* attribute is checked. TLM read requests are translated into calls to the *read* API function of the icache or ilocalram respectively. TLM write requests are ignored.

The dcio data cache socket transport function is more deeply structured. In contrast to the icio socket, the dcio payload supports address space identifiers (ASIs – see 5.1.2). The ASIs are implemented as an optional extension to the TLM2 generic payload. Depending on the ASI the dcio transport function calls functions from different sub-component APIs. Default cache access is performed for ASI 0x8, 0x9, 0xa and 0xb. Other modes are used to access system registers (0x2), tag rams (0xc, 0xe), cache data blocks (0xd, 0xf), mmu internal registers (ASI 0x19) and more. Next to TLM read request, TLM write requests are supported.

The class also contains the Cache Control Register, which is implemented as a 32bit unsigned integer (see Table 5).

### The vectorcache.h/cpp files

The files vectorcache.h and vectorcache.cpp define a common base class for the implementation of instruction and data caches. Almost all the functionality required by both cache types is implemented here.

/// read from cache  
void read(unsigned int address, unsigned char \* data, unsigned int len, sc\_core::sc\_time \* t, unsigned int \* debug);

The API consists of a set of protected member functions, which are ougth to be published by child classes. In the following these functions are briefly explained:

To be called for ordinary load operations. The address parameter will be split into a cache tag and a cache index portion. Afterwards, the cache line with the respecting index is loaded and checked. If the tag in one of the sets matches and the valid bit is set, the cache entry is copied to the \*data pointer (read hit). In case the tags do not match or the valid bit is not set, the request is forwarded to the ahb interface or to the mmu (read miss). After miss processing, the fresh data is filled into the cache and copied to the \*data pointer.

/// write through cache  
void write(unsigned int address, unsigned char \* data, unsigned int len, sc\_core::sc\_time \* t, unsigned int \* debug);

The write function is supposed to be called for ordinary store operations. The address parameter will be split into a cache tag and a cache index portion. Afterwards, the cache line with the respecting tag is loaded and checked. If the tag in one of the sets matches and the valid bit is set, the respective data entry is updated and the request is forwarded to the mmu or the ahb interface (write hit). If the tag does not match or the valid bit is not set the request directly goes to mmu or ahb interface (write miss). The cache will not be updated with the write data. The write policy is write-through with no-allocate on write miss.

/// flush cache  
void flush(sc\_core::sc\_time \* t, unsigned int \* debug);

Flushes the cache*.* During a cache flush all valid data in the cache is transferred to main memory for synchronization.

/// read data cache tags (ASI 0xe)

void read\_cache\_tag(unsigned int address, unsigned int \* data, sc\_time \*t);

/// write data cache tags (ASI 0xe)

void write\_cache\_tag(unsigned int address, unsigned int \* data, sc\_time \*t);

/// read data cache entries/data (ASI 0xf)

void read\_cache\_entry(unsigned int address, unsigned int \* data, sc\_core::sc\_time \*t);

/// write data cache entries/data (ASI 0xf)

void write\_cache\_entry(unsigned int address, unsigned int \* data, sc\_time \*t);

These functions are used for diagnostic access to cache tags and cache entries (see 5.1.4).

unsigned int read\_config\_reg(sc\_core::sc\_time \*t);

Returns the configuration register of the cache. The Cache Configuration Register is initialized in the constructor of class mmu\_cache. The register is read only.

virtual unsigned int check\_mode() = 0;

A cache can be in one of three different modes of operation: enabled, disabled or frozen. The current mode must be defined by checking the Cache Control Register, which is implemented in the top-level class mmu\_cache. Depending on the type of cache (instruction or data) the DCS or ICS bits of the CCR must be checked. Therefore, the check\_mode function is plain virtual. The function must be overwritten by the actual icache or dcache implementation.

### The ivectorcache.h/cpp files

The class ivectorcache contains the actual implementation of the instruction cache. The class inherits from class vectorcache. All interface functions are made public. The write function is overwritten, because the instruction cache is not writable. A call to the write function will emit an error message and stop the simulation.

The class implements the virtual check\_mode function. For checking the mode of operation the ICS bits of the Cache Control Register are used.

### The dvectorcache.h/cpp files

The class dvectorcache contains the actual implementation of the data cache. The class inherits from class vectorcache. All interface functions are made public.

The virtual check\_mode function is implemented. For checking the mode of operation the DCS bits of the Cache Control Register are used.

### The localram.h/cpp files

The class localram models a fast scratchpad memory that can be attached to both instruction and data cache controllers. The actual memory is implemented as a c++ std::vector. The class inherits the generic memory interface (mem\_if) and provides implementations for reading and writing data.

### The mmu.h/cpp files

The files implement the memory management unit of the Cache Sub-System. The component was modeled following the recommendations for the SparcV8 reference MMU given in [RD08]. The class mmu receives the number of instruction tlbs, the number of data tlbs, the tlb type, the tlb replacement policy and the mmu page size as constructor arguments. Depending on the tlb type two split TLBs or one shared TLB is generated for instructions and data. The TLBs are implemented as STL std::map containers. The key for a TLB lookup is a virtual address tag (t\_VAT). The caches connect to the mmu through tlb\_adapter objects (section 5.2.11). In shared TLB mode only one adapter is generated. Next to the adapter objects the class mmu offers a set of API functions. The most important of these functions is:

unsigned int tlb\_lookup(unsigned int addr, std::map<t\_VAT, t\_PTE\_context> \* tlb, unsigned int tlb\_size, sc\_core::sc\_time \* t, unsigned int \* debug);

The tlb\_lookup function is responsible for translating virtual addresses into physical addresses. It receives the virtual address and a TLB pointer as arguments. In the function body, the virtual address is split into three indices. The bit width of these indices depend on the virtual page size. The following page sizes and index combinations are supported (Table 10):

|  |  |  |  |
| --- | --- | --- | --- |
| virt. page size | idx 1 | idx 2 | idx 3 |
| 4kb | 8 bit | 6 bit | 6 bit |
| 8kb | 7 bit | 6 bit | 6 bit |
| 16kb | 6 bit | 6 bit | 6 bit |
| 32kb | 4 bit | 7 bit | 6 bit |

Table 12 - Page size / index combinations

In case of a TLB miss the indices are used for addressing the page tables in main memory. A successful read of a page table returns either a page table descriptor (PTD) or a page table entry (PTE). A PDC is a pointer to the next-level page table, while a PTE corresponds to an actual TLB entry. Up to three page table levels are supported.

The mmu contains a set of internal control registers. These registers can be accessed through the ASI 0x19 (Table 7). Respective read and write requests are translated into calls to following functions:

// read mmu internal registers (ASI 0x19)

unsigned int read\_mcr();

unsigned int read\_mctpr();

unsigned int read\_mctxr();

unsigned int read\_mfsr();

unsigned int read\_mfar();

// write mmu internal registers (ASI 0x19)

void write\_mcr(unsigned int \* data);

void write\_mctpr(unsigned int \* data);

void write\_mctxr(unsigned int \* data);

Another group of member functions is dedicated to diagnostic TLB access. The addressing of the different bit fields can be taken from [RD08].

// diagnostic read/write of instruction PDC (ASI 0x5)

void diag\_read\_itlb(unsigned int addr, unsigned int \* data);

void diag\_write\_itlb(unsigned int addr, unsigned int \* data);

// diagno. read/write of data PDC or shared instruction and data PDC (ASI 0x6)

void diag\_read\_dctlb(unsigned int addr, unsigned int \* data);  
void diag\_write\_dctlb(unsigned int addr, unsigned int \* data);

### The tlb\_adaptor.h file

The class *tlb\_adapter* implements the generic memory interface *mem\_if*. Depending on the configuration the *mmu* creates one or two objects of *tlb\_adapter*, which provide access to the instruction and/or data tlb. Pointers to these objects can be obtained by calling the mmu API functions *get\_itlb\_if* and *get\_dtlb\_if*.

## Parametrization Options

The Cache-Subsystem can be parametrized through the constructor parameters of the top-level class (*mmu\_cache*). The parameters shown in Table 11 directly refer to VHDL generics with the same name.

|  |  |
| --- | --- |
| Parameter | Description |
| dsu | Enable debug support unit interface (not implemented) |
| icen | Enable instruction cache |
| irepl | Icache replacement strategy  00 = non, 01 = LRU, 10 = LRR, 11 = random |
| isets | Number of instruction cache sets (1-4) |
| ilinesize | Indicates size of instruction cache line in words (line size = 2^ilinesize, ilinesize <= 3) |
| isetsize | Indicates size (kbytes) of instruction cache set  (set size = 2^isetsize, isetsize <= 6 (max 64 kbytes)) |
| isetlock | Enable instruction cache locking |
| dcen | Enable data cache |
| drepl | Dcache replacement strategy  00 = non, 01 = LRU, 10 = LRR, 11 = random |
| dsets | Number of data cache sets (1-4) |
| dlinesize | Indicates size of data cache line in words  (line size = 2^dlinesize, dlinesize <= 3 ) |
| dsetsize | Indicates size (kbytes) of data cache set  (set size = 2^dsetsize, dsetsize <= 6 (max. 64 kbytes)) |
| dsetlock | Enable data cache locking |
| dsnoop | Enable data cache snooping |
| ilram | Enable instruction scratchpad |
| ilramsize | Indicates size of instruction scratchpad in kbytes  (size = 2^ilramsize, ilramsize <= 9 (max. 512 kbytes)) |
| ilramstart | 8 MSB bits used to decode local instruction RAM area (16 MB segm.) |
| dlram | Enable data scratchpad |
| dlramsize | Indicates size of data scratchpad in kbytes  (size = 2^dlramsize, dlramsize <= 9 (max. 512 kbytes)) |
| dlramstart | 8 MSB bits used to decode local data RAM area (16 MB segment) |
| cached | Fixed cacheability mask (overrides AMBA Plug & Play settings) |
| mmu\_en | Enable MMU |
| Itlb\_num | Indicates number of instruction TLBs  (tlb number = 2^itlb\_num, itlb\_num <= 5 (max. 32)) |
| dtlb\_num | Indicates number of data TLBs  (tlb number = 2^dtlb\_num, dtlb\_num <= 5 (max. 32)) |
| tlb\_type | TLB implementation type  0 = separate, 1 = shared instruction and data TLB |
| tlb\_rep | TLB replacement policy  0 = LRU, 1 = random |
| mmupgsz | MMU page size  0, 2 = 4kbytes, 3 = 8kbytes, 4 = 16kbytes, 5 = 32kbytes |

Table 13 - Constructor Configuration Parameters

The constructor parameter shown in Table 12 are timing or simulation related.

|  |  |
| --- | --- |
| Parameter | Description |
| name | Name of the SystemC component |
| id | ID of the AHB master interface |
| icache\_hit\_read\_response\_delay | Delay of an icache read-hit |
| icache\_miss\_read\_response\_delay | Delay of an icache read-miss |
| dcache\_hit\_read\_response\_delay | Delay of a dcache read-hit |
| dcache\_miss\_read\_response\_delay | Delay of a dcache read-miss  (without AHB delay) |
| dcache\_write\_response\_delay | Delay of a dcache write-hit and write-miss  (without AHB delay) |
| itlb\_hit\_response\_delay | Delay of an ITLB hit |
| itlb\_miss\_response\_delay | Delay of an ITLB miss  (without AHB delay for table walk) |
| dtlb\_hit\_response\_delay | Delay of a DTLB hit |
| dtlb\_miss\_response\_delay | Delay of a DTLB miss  (without AHB delay for table walk) |

Table 14 - Constructor Simulation Parameters

## Interface

The interface of the module comprises three TLM2 sockets.

tlm\_utils::simple\_target\_socket<mmu\_cache> icio / bind to CPU instruction socket

tlm\_utils::simple\_target\_socket<mmu\_cache> dcio / bind to CPU data socket

amba::amba\_master\_socket<32> ahb\_master / bind to AMBA system bus

## Compilation Instructions

For the compilation of the Cache-Subsystem IP, a WAF wscript is provided and integrated in the superordinate build mechanism of the TLM model library of the Hardware-Software SystemC Co-Simulation SoC Validation Platform project.

The compilation flow creates a static library of the IP model, which can be linked against testbenches or platform simulations.

Currently the following testbenches are available:

|  |  |
| --- | --- |
| Name / Target | Description |
| lt\_ct\_default\_test  *waf –target lt\_ct\_default.test* | Tests most of the fundamental functionality of the cache e.g. instruction/data read/write hit/miss, diagnostic read/write of cache tags and entries, cache flushing, sub-word access, cache bypass mode and cache freeze.  Configuration summary: caches enabled, mmu disabled, localrams disabled, 4 instruction and data cache sets, 1kb instruction and data cache set size, 1 word per cacheline\*, caches random replacement |
| lt\_ct\_localram\_test  *waf –target lt\_ct\_localram.test* | Tests the cache in a different configuration (2 large sets) and the localrams at maximum size (512kb each).  Configuration summary: caches enabled, mmu disabled, localrams enabled, 2 instruction and data cache sets, 256kb instruction and data cache set size, 512kb instruction and data localram size, 1 word per cacheline\*,  caches random replacement |
| lt\_ct\_lock\_test  *waf –target lt\_ct\_lock.test* | Test for caches with 3 sets. Main purpose is the test of different replacement strategies (LRU, LRR). Todo: add vectors for cache line locking  Configuration summary: caches enabled, mmu disabled, localrams disabled, 3 instruction and data cache sets, 8kb instruction and data cache set size, 4 words per cacheline,  icache LRR replacmenet, dcache LRU replacement |
| lt\_ct\_mmu\_test  *waf –target*  *lt\_ct\_mmu.test* | Test for mmu and tlbs. The test initializes a 3-level page table in main memory. Afterward instruction and data tlb hits/misses are simulated and verified.  Configuration summary: caches enabled, mmu enabled, localrams disabled, 4 instruction and data cache sets, 1kb instruction and data cache size, 1 word per cacheline\*, 8 instruction and data tlbs, 4kB mmu page size |
| lt\_ct\_cacheline\_test  *waf –target*  *lt\_ct\_cacheline.test* | Tests random replacement and instruction burst fetch on cache configuration with 8 words per line (max).  Configuration summary: caches enabled, mmu disabled, localrams disabled, 2 instruction and data cache sets, 64kb instruction and data cache size, 8 words per instruction and data cache line, caches random replacement |

Table 15 - Tests Cache Sub-System

\*Configuration not supported by hardware model.

All tests are located in the *models/mmu\_cache* directory.

## Example Instantiation

The following example demonstrates the instantiation of the *mmu\_cache* module (e.g. within a sc\_main()) and the correct binding of the TLM sockets.

*Instantiation of mmu\_cache with example configuration:*

 1 mmu\_cache m\_mmu\_cache(  
 2         1,             // icen: instruction cache enabled  
 3         3,             // irepl: instruction cache random replacement  
 4         1,             // isets: 2 instruction cache sets  
 5         3,             // ilinesize: 8 words per instruction cache line  
 6         6,             // isetsize:       64 kb per instruction cache set  
 7         0,             // isetlock: no instruction cache locking  
 8         1,             // dcen: data cache enabled  
 9         3,             // drepl: data cache random replacement  
10         1,             // dsets: 2 data cache sets  
11         3,             // dlinesize: 8 words per data cache line  
12         6,             // dsetsize: 64 kb per data cache set  
13         0,             // dsetlock: no data cache locking  
14         0,             // dsnoop: no data cache snooping  
15         0,             // ilram: disabled  
16         0,             // ilramsize: 1kb  
17  0x8e,    // ilramstart: 0x8e000000 start address of ilram (disabled)  
18         0,             // dlram: disabled  
19         0,             // dlramsize: 1kb  
20  0x8f,            // dlramstart: 0x8f000000 start address of dlram (disabled)  
21         0,             // cached: no cachability mask  
22         0,             // mmu\_en: no mmu  
23         3,             // itlb\_num: 8 ITLBs (disabled)  
24         3,             // dtlb\_num: 8 DTLBs (disabled)  
25         0,             // tlb\_type: separate instruction and data TLBs (disabled)  
26         1,             // tlb\_repl:       random TLB replacement  
27         0,             // mmupgsz: 4kb  
28         **"mmu\_cache"**,   // name: SystemC module name  
29         2,             // id: AHB master ID  
30         sc\_core::sc\_time(0, sc\_core::SC\_NS),   // icache\_read\_hit\_response\_delay  
31         sc\_core::sc\_time(0, sc\_core::SC\_NS),   // icache\_read\_miss\_response\_delay  
32         sc\_core::sc\_time(0, sc\_core::SC\_NS),   // dcache\_read\_hit\_response\_delay  
33         sc\_core::sc\_time(0, sc\_core::SC\_NS),   // dcache\_read\_miss\_response\_delay  
34         sc\_core::sc\_time(0, sc\_core::SC\_NS),   // dcache\_write\_response\_delay  
35         sc\_core::sc\_time(0, sc\_core::SC\_NS),   // itlb\_hit\_response\_delay  
36         sc\_core::sc\_time(0, sc\_core::SC\_NS),   // itlb\_miss\_response\_delay  
37         sc\_core::sc\_time(0, sc\_core::SC\_NS),   // dtlb\_hit\_response\_delay  
38         sc\_core::sc\_time(0, sc\_core::SC\_NS));  // dtlb\_miss\_response\_delay  
   
*Bind AHB master socket to e.g. AMBA\_LT\_CT\_Adapter:*   
 1 mmu\_cache.ahb\_master(ahb\_lt\_ct.slave\_sock);  
   
*Bind icache and dcache interfaces to testbench/processor:*   
 1 tb.instruction\_initiator\_socket(mmu\_cache.icio);  
 2 tb.data\_initiator\_socket(mmu\_cache.dcio);

# Aeroflex Gaisler GPTIMER General Purpose Timer

## Functionality and Features

The GPTimer unit acts as a slave at the APB bus. Its basic functionality is a countdown mechanism that asserts an interrupt on underflow. The GPTimer unit consists of a prescaler unit that is generating ticks and up to seven counter units that are decrementing on prescaler ticks. In the VHDL model, the counter units are named ‘timers’ just like the entire IP model. As this is a potential source of confusion, the name has been changed to ‘counters’ in the TLM implementation.

The GPTimer unit can be configured and operated through its registers addressed through the APB interface. All registers have a width of 32 bits and are summarized in Table 13.

|  |  |
| --- | --- |
| APB Address Offset | Register |
| 0x00 | Scaler Value |
| 0x04 | Scaler Reload Value |
| 0x08 | Configuration Register |
| 0x0C | Unused |
| 0xn0 | Counter n Value Register |
| 0cn4 | Counter n Reload Register |
| 0xn8 | Counter n Configuration Register |
| 0xnC | Unused |

Table 16 – GPTimer Registers

The prescaler and all the timers are equipped with a value register and a reload value register. The value register is decremented on each trigger and can be reset to the reload value on underflow or on reset command. In the VHDL model, the trigger for decrementing the prescaler is the bus clock input of the GPTimer unit. In the SystemC model the prescaler ticks are calculated by multiplying the clock period with the prescaler reload register. The clock period is stored to the ‘clock\_cycle’ variable, which can be set using one of the overloaded ‘clk’ functions. The triggers for decrementing the counters are ticks issued by prescaler underflow. The prescaler is automatically reset on underflow and cannot be halted. Due to a specific characteristic of the VHDL implementation of the GPTimer unit, the prescaler reload value must be greater than or equal to the number of counters implemented in the GPTimer instance.

The configuration register located at address 0x08 can be used to configure the GPTimer unit. The counter n configuration registers located at addresses 0xn8 can be used to configure the individual counters.

The configuration register consists of four fields, DF, SI, IRQ, and TIMERS. The DF field is the only field that can by modified dynamically, all other fields are read only, i.e. their values are determined by VHDL generics and written to the registers at system startup.

The **DF (disable freeze) field** disables the sensitivity to the dhalt input signal. This signal can be used to freeze the timer value registers, if DF is disabled.

The **SI (separate interrupt) field** specifies whether each counter asserts an individual interrupt line or all counters assert the same interrupt line. If all counters assert the same interrupt line, this line is specified in the **IRQ field**. Else, counter 1 asserts the interrupt specified in the IRQ field and all other counters are distributed to the subsequent lines. The highest line must not exceed the maximum number of interrupts in the system. For more information on the interrupt scheme, please refer to chapter 7.

The **TIMERS field** specifies the number of counters in the system.

The counter configuration registers are used to configure and control the counters. The counters are controlled by the enable, load, and debug halt fields. Debug halt freezes the counter value register, load immediately reloads the value register with the contents of the reload value register, and enable can be used to enable or disable the counter.

To increase the counting delay, chaining can be activated for individual counters. If counter n is chaining mode, it does not decrement on prescaler ticks, but on ticks generated by an underflow of the previous counter (n-1). For this operating mode, counter (n-1) must be in restart mode, i.e. its value register is automatically reloaded from the reload value register on underflow. In addition, the interrupt assertion of a counter can be disabled, which would be reasonable for counter (n-1) in the described example. It is possible to enable chaining for multiple counters to wait for very long periods.

In addition, it is possible to configure the last counter as a watchdog using the wdog generic. This generic can be set to an alternative reload value, which will be used to set and reload the counter. The watchdog counter will be started on timer reset and cause an assertion of the wdog output on underflow.

## Internal Structure

The TLM implementation of the GPTimer comprises two classes, CGPTimer and CGPCounter. Implementing the counter unit in a class of its own enables the GPTimer unit to be instantiated with a variable number of counters, which are dynamically instantiated in the constructor of the CGPTimer class. For both classes, the definition is put into header files (gptimer.h, gpcounter.h) and the implementation is put into c++ source files (gptimer.cpp, gpcounter.cpp). The contents of these files are described in the subsequent sections.

### The gptimer.h file

The ‘gptimer.h’ file contains the module class definition. Any communication with the environment is performed through the CGPTimer class defined in this file. The Counters are fully encapsulated in the Timer module.

#### Parameterization of the module

The parameterization options, implemented as generics in the VHDL model, are realized as constructor parameters of the CGPTimer class. This makes the module parametrizable during instantiation. Details on the parameters are given in section 7.3.

#### Configuration of the module

The GPTimer unit is configurable through its Timer configuration register and its Counter configuration registers. The configuration registers, which are accessible through the APB bus, are modeled and accessed through the comfortable mechanisms provided by GreenReg. To ensure GreenReg compatibility, the CGPTimer class needs to be a child module of a GreenReg Device. A gr\_device is a top-level encapsulation for a complete functional unit and provides containment structures for other GreenReg elements, e.g. registers. Thus, the CGPTimer class inherits the gr\_device class.

The ‘gptimer.h’ file contains const variables defining register addresses and bit masks. These definitions are made for programming convenience.

The write masks of the registers can be used to ensure that only permitted bits are set when writing to a register. They can also be applied for reading specific fields of a register masking all other bits.

#### Communication with the module

Apart from the APB communication directed to the registers of the GPTimer, the module is equipped with five signals for direct communication with the master devices.

* The **rst input** signal triggers the reset function do\_reset of the module….
* The **dhalt input** signal is a debug signal that can be used to freeze the counters. This signal can be deactivated through setting the DF bit in the configuration register.
* The **tick output** signal is used for debugging purposes only. Whenever a tick is generated by the prescaler or an underflow of any counter occurs, the tick signal will be set to a number assigned to this instance (1 – prescaler; 2..n+1 – Counters).
* The **IRQ output** signal is used to launch an interrupt on counter underflow. The according interrupt line will be provided as the value of this uint32\_t type signal.
* The **wdog output** signal is required if the timer is used as a watchdog. The signal will then be asserted on underflow of Counter 1.

#### Operation of the module

The CGPTimer class definition contains the module interface and the function prototypes of constructor, destructor, SystemC proesses, callback functions, and pure C++ software routines. The GPTimer unit needs to assert interrupt signals at the correct points of time and therefore needs an SC\_THREAD process to keep track of time. A second SC\_THREAD is used for debug only and is disabled by default.

The SystemC processes have to be registered with the SystemC simulation kernel using the SystemC macro, SC\_HAS\_PROCESS(). In a similar fashion, the callback functions, which are hooked to the registers built with GreenReg, are registered with the SystemC simulation kernel using the GreenControl macro, GC\_HAS\_CALLBACKS().

In addition, some class attributes are defined to keep track of the overall state of operation of the module:

* A lasttime variable stores the last timestamp at which the value of the prescaler has been know. This time is required as a reference for any calculation of ticks.
* A lastvalue variable stores the contents of the prescaler value register at the time stored in lasttime. The prescaler value is known when it is calculated With the information given in lasttime and lastvalue it is possible to calculate the next tick.

## Parametrization Options

The model can be parametrized through the constructor arguments of class timer. All available options are listed in Table 15.

|  |  |
| --- | --- |
| Parameter | Description |
| name | The name of the SystemC instance |
| ntimers | Number of counters (1-7) |
| pirq | Defines which APB interrupt the timers will generate. |
| sepirq | If set to 1, each timer drives an individual interrupt line, starting with interrupt pirq. If set to 0, all timers will drive the same interrupt line. |
| nbits | Bitwidth of the counters |
| sbits | Bitwidth of prescaler |
| wdog | Watchdog reset value. |

Table 17 - GPTimer Parameters

## Interface

The control registers of the module can be accessed through a GreenSocs APB slave socket. In addition, the module provides a set of SignalKit sockets. All socket are implemented in the Timer top-level class.

|  |  |  |  |
| --- | --- | --- | --- |
| Name | Type | In/Out | Description |
| rst | bool | in | reset prescaler and all counters |
| dhalt | bool | in | debug halt |
| tick | uint8\_t | out | muxed ticks of prescaler (bit 0) and all counters (bit 1-7) |
| irq | uint32\_t | out | interrupt lines |

Table 18 - Timer SignalKit sockets

## Compilation Instructions

For the compilation of the Timer IP, a WAF wscript is provided and integrated in the superordinate build mechanism of the TLM model library of the Hardware-Software SystemC Co-Simulation SoC Validation Platform project.

## Example Instantiation

*Instantiation of Timer with 4 Counters:*

 1 Timer dut(**"timer"**, 4);  
 2   
 3 Bind APB socket:  
 4   
 5 tb.master\_sock(dut.bus);  
 6   
 7 Bind SignalKit ports:  
 8   
 9 dut.rst(tb.rst);  
10 dut.dhalt(tb.dhalt);  
11 tb.tick(dut.tick);  
12 tb.irq(dut.irq);

# Aeroflex Gaisler IRQMP Interrupt Controller

## Functionality and Features

### Overview

The functionality of the TLM implementation of the IRQMP unit is equivalent to that of the Gaisler GRLIB VHDL implementation described in RD04. It is compliant with the GRLIB interrupt (IR) scheme described in RD05.

The GRLIB IR scheme comprises a 32-bit IR bus, which is routed in parallel to the AMBA bus signals. The 16 LSBs of the IR bus form the vector of regular IRs, which can be handled by the LEON III core. The 16 MSBs of the IR bus form the extended IR (EIR) vector applicable for systems that require more than 16 IRs. The EIR handling will be explained later in this section.

The AHB and APB units may assert IR lines. The assertions on each line are disjunctively combined by the bus controller and monitored by the IRQMP unit. After prioritization and masking, the IRQMP unit forwards the IRs to the according processors.

The IRQMP unit supports multi-processor systems with up to 16 LEON3 cores. Two different modes of interrupt forwarding are provided:

1. The IR is forwarded to all cores and cleared by the first core that acknowledges the IR (i.e. the ISR is processed only once).
2. The IR is broadcasted and has to be acknowledged (and processed) by each of the cores.

Interrupts can be masked for each core separately.

The data path of the IRQMP unit is not pipelined, i.e. all operations can be performed within one clock cycle. The behavior can be configured setting the registers summarized in Table 17. All registers have a width of 32 bits.

|  |  |
| --- | --- |
| APB Address Offset | Register |
| 0x00 | Interrupt Level Register |
| 0x04 | Interrupt Pending Register |
| 0x08 | Interrupt Force Register (NCPU = 0) |
| 0x0C | Interrupt Clear Register |
| 0x10 | Multiprocessor Status Register |
| 0c14 | Broadcast Register |
| 0x40 + 4 \* n | Processor n Interrupt Mask Register |
| 0x80 + 4 \* n | Processor n Interrupt Force Register |
| 0xC0 + 4 \* n | Processor n Extended Interrupt Identification Register |

Table 19 – IRQMP Registers

### Interrupt Prioritization and Forwarding

The IRs are prioritized in a two-dimensional prioritization scheme. Both dimensions are referred to as “interrupt level” in RD04. For clarification purposes, terms will be redefined for this document.

The first dimension of prioritization is determined by the Interrupt Level Register. For each IR line, the according bit in the IR Level Register can be set to level 1 or level 0. Each level 1 IR has got a higher priority than any level 0 IR. The first dimension of prioritization will be referred to as “interrupt level” throughout this document.

The 16 regular IR lines are modeled with a 16-bit vector. The most significant bit (IR15) has got the highest priority and IR1 has got the lowest priority. IR0 is reserved. This second dimension of prioritization will be referred to as “interrupt line” throughout this document.

When several IRs are pending, the highest priority IR will be calculated according to the scheme described above. The determination of which cores will receive the interrupt request (IRQ) depends on the Broadcast Register and the Interrupt Mask Registers of the individual cores. In the Scheme of interrupt distribution, as shown in Figure 7, the use of the IR Pending or IR Force Registers is determined by the Broadcast Register.

Figure 9 – Interrupt Distribution Scheme

The Interrupt Broadcast Register can be set for each IR line individually. If the broadcast bit of an interrupt line is set, the IRQ is sent to all cores and has to be acknowledged (i.e. the ISR has to be processed) by each of the cores. This is realized by setting the Interrupt Force Registers for all cores. Each core has to clear its Interrupt Force register separately.

If the broadcast bit is not set, the IRQ is sent to all cores and has to be acknowledged only once, i.e. only the first core that acknowledges the IR has to process the ISR. This is realized by setting the Interrupt Pending Register, which can be cleared by any of the cores. In uniprocessor systems the Broadcast Register is disabled.

Interrupts can be masked for each core individually. If bit n of the Interrupt Mask Register of core m is set to 0, then interrupt n is masked for this core, i.e. core m will never receive IRQ n. As a matter of fact, the VHDL implementation does not prevent an interrupt n clearance by core m in this case. For now, the SystemC module has been aligned to this behavior.

Interrupt masking takes place before prioritization, so the highest priority unmasked IR is always forwarded to the processors.

Interrupt 15 cannot be maskable by the LEON3 core and should be used with care. Most operating systems do not safely handle this IR.

### Extended Interrupt Handling

Extended interrupts are implemented in a cascaded fashion, i.e. one of the regular IR lines may be defined as a cascade for the 16 EIR lines. The cascade is defined in bits 19..16 of the Multiprocessor Status Register.

If EIRs are asserted and the cascade is the highest priority active regular IR, the cascade is forwarded to the cores. After receiving the interrupt acknowledge signal from a core, the IRQMP unit writes the number of the asserted EIR line into the Extended Interrupt Identification Register. Thus, the ISR of the cascade has to send the acknowledge signal and afterwards read the EIR ID Register to call the correct ISR of the asserted EIR.

### Processor Status Monitoring

[This section is copied from RD04]

The processor status can be monitored through the Multiprocessor Status Register. The STATUS field [15..0] in this register indicates if a processor is halted (‘1’) or running (‘0’). A halted processor can be reset and restarted by writing a ‘1’ to its staus field. After reset, all processors except processor 0 are halted. When the system is properly initialized, processor 0 can start the remaining processors by writing to their STATUS bits.

## Internal Structure

The source code is split into three files, ‘irqmpreg.h’, ‘irqmp.h’, and ‘irqmp.tpp’.

### The irqmpregisters.h File

The ‘irqmpreg.h’ file contains preprocessor definitions of register addresses and bit masks only. These definitions are made for programming convenience.

The write masks of the registers can be used to ensure that only permitted bits are set when writing to a register.

The default masks are written to the registers in the system-reset function.

### The irqmp.h File

The IRQMP unit consists of only one class. The ‘irqmp.h’ file contains the module class definition. The parameterization options, implemented as generics in the VHDL model, are realized as constructor parameters of the class. Details are given in section 8.3.

To ensure GreenReg compatibility, the Irqmp module needs to be a child module of a GreenReg Device. A gr\_device is a top-level encapsulation for a complete functional unit and provides containment structures for other GreenReg elements, e.g. registers. Thus, the Irqmp class inherits the gr\_device class.

The Irqmp class definition contains the module interface and the function prototypes of constructor, destructor, and callback functions. Processes are not used in the module.

SystemC processes are registered with the SystemC simulation kernel using the SystemC macro, SC\_HAS\_PROCESS(). In a similar fashion, the callback functions, which are hooked to the registers built with GreenReg, are registered with the SystemC simulation kernel using the GreenControl macro, GC\_HAS\_CALLBACKS().

### The irqmp.tpp file

The ‘irqmp.tpp’ file is technically a header file, which is included at the bottom of the ‘irqmp.h’ file. It implements all the member functions of the Irqmp template class, including constructor and destructor.

The destructor is explicitly defined to unregister the callback functions.

The constructor configures the gr\_device and the bus interface. It constructs a GreenReg register container ‘r’, in which it implements all the registers listed in Table 17. The register container is a C++ class implemented in the GreenReg libraries that provides memory management and interface functions. Within this register container, a GreenReg register may be instantiated like in the following code snippet.

1 r.create\_register(**"pending"**, **"Interrupt Pending Register"**,  
2                   0x04,  
3                   STANDARD\_REG | SINGLE\_IO | SINGLE\_BUFFER | FULL\_WIDTH,  
4                   0x00000000,  
5                   IRQMP\_IR\_PENDING\_EIP | IRQMP\_IR\_PENDING\_IP,  
6                   32,  
7                   0x00  
8                  );

The arguments to the ‘create\_register()’ function are name, description, offset, configuration, init value, write mask, register width, and lock mask. For a detailed description of these options, please refer to the GreenReg documentation.

In addition to building the interface, the constructor registers the sensitivity of the three SC\_METHOD processes with the simulation kernel. These processes are sensitive to signals that are not part of the standard AMBA interface and therefore cannot be implemented as callback functions hooked to the registers.

The constructor only takes care of building the registers. For hooking the callback functions to the registers, the use of the built-in SystemC function end\_of\_elaboration() is required. It is called at the end of the elaboration process, in which all instances of all models are built and all functions and processes are compiled. So after elaboration, the SystemC simulation kernel is made aware of the callback functions being hooked to the specific registers. This is achieved by subsequently using the GreenReg macros GR\_FUNCTION and GR\_SENSITIVE as shown exemplarily in the following code snippet.

1 GR\_FUNCTION(Irqmp, launch\_irq);  
2 GR\_SENSITIVE(r[PENDING].add\_rule(POST\_WRITE, **"launch\_irq"**, NOTIFY));

This code hooks the ‘launch\_irq’ callback function of the gr\_device ‘Irqmp’ to the register administrated by the register container ‘r’ at the address ‘PENDING’, which has been defined to be 0x04 in a preprocessor directive. The ‘POST\_WRITE’ argument indicates that the callback function is to be called after a write access to the register. The ‘NOTIFY’ argument simply indicates that the function is to be called at every write access without any conditions or parameters. ‘POST\_WRITE’ and ‘NOTIFY’ are the only options used with the ‘add\_rule()’ function within the IRQMP module.

The member functions of the module merely implement its functionality as described in Section 8.1 and therefore do not need to be explained explicitly. There are no interdependencies between the functions. The function names have been chosen to be self-explanatory.

As the IRQMP unit consists of combinational logic only (except for the interface registers), the implementation of the temporal behavior is rather simple. We assume that each operation will be completed within one clock cycle. Hence, there is no use of different implementations for LT and AT modeling.

For the callback functions, the delay of one clock cycle can simply be achieved by using ‘GR\_DELAYED\_SENSITIVE’ instead of ‘GR\_SENSITIVE’ during the callback registration within the ‘end\_of\_elaboration()’ function.

For the SC\_METHOD processes, the delay is modeled by temporarily overriding the static sensitivity of the methods by using the SystemC ‘next\_trigger()’ function with a constant delay. That way the SC\_METHOD is always called twice – once to model the delay and once to model the functionality. As no wait statements are required, this way of modeling allows maximum simulation performance.

## Parametrization Options

In the VHDL implementation, the parameterization is fully controlled by generics, which are supported as constructor parameters in the SystemC module. The parameters are summarized in Table 18.

|  |  |  |  |
| --- | --- | --- | --- |
| **Parameter** | **Function** | **Allowed Range** | **Default** |
| pindex | Selects which APB select signal (PSEL) will be used to access the IRQMP unit | 0 to  NAPBMAX – 1 | 0 |
| paddr | The 12-bit MSB APB address | 0 to 4095 | 0 |
| pmask | The APB address mask | 0 to 4095 | 4095 |
| ncpu | Number of processors in multicore systems | 1 to 16 | 1 |
| eirq | The cascade line of EIRs | 0 to 15 | 0 |

Table 20 - Template Parameters

## Interface

The interface of the IRQMP unit can be divided in two parts, APB bus communication and direct processor communication.

### APB Bus Communication

The APB bus communication mainly consists of the registers listed in Table 17. In addition, the reset signal and the irq\_in signal is implemented to model the input vector of the interrupt lines from the bus.

All registers can be written to configure or operate the IRQMP unit. As the only exception, the Extended Interrupt Identification Register is a read-only register. The function and configuration options of the registers are described in full detail in section 54.3 of RD04. However, two differences between RD04 and the SystemC implementation have to be noted:

1. The Interrupt Force Register for NCPU = 0 has been left out in the SystemC implementation. In a single-processor system the function of the Interrupt Force Register is identical to that of the Interrupt Pending Register.
2. In RD04 it is stated that the bits [31..17] of the Interrupt Clear Register are all constantly pulled down to ‘0’. This differs from the VHDL implementation, in which these bits are used for extended interrupt clearance. Using this way of clearance, an EIR can also be cleared by software. The SystemC implementation follows the VHDL implementation rather than the manual.

To enable the communication with the registers, the module contains an APB slave socket. The socket can be bound to any compatible APB master socket that may initiate TLM transactions calling the according b\_transport or nb\_transport functions. The register address would then be part of the TLM2.0 generic payload.

### Direct Processor Communication

For immediate access to the reset signals and the IRQ registers of the cores, the IRQMP unit provides an interface for direct processor communication. The interface consists of the signals,cpu\_rst, irq\_req, and irq\_ack.

An active signal ‘irq\_ack’ from the core indicates that the IR on the line specified by the signal is acknowledged by the core. The core is recognized automatically by means of the signal kit. The according IR is then cleared from the Interrupt Pending Register or the Interrupt Force Register of this core.

The ‘irq\_req’ signal sends an interrupt request to the cores and contains the pending interrupt line number.

The ‘cpu\_rst’ signal is used to suspend and wake up the core.

## Compilation Instructions

For the compilation of the IRQMP unit, a WAF wscript file is provided and integrated in the superordinate build mechanism of the TLM model library of the Hardware-Software SystemC Co-Simulation SoC Validation Platform project.

The libraries required for the compilation are:

1 #include **<boost/config.hpp>**  
2 #include **<systemc.h>**  
3 #include **<greenreg.h>**  
4 #include **<greenreg\_ambasocket.h>**  
5 #include **"greencontrol/all.h"**  
6 #include **"irqmpregisters.h"**  
7 #include **"signalkit.h"**

## Example Instantiation

The following example shows how to instantiate the IRQMP TLM and connect it to a testbench. To enable the simulation of the system, all signals of the IRQMP module need to be connected to the sc\_main signals.

1 #include **"amba.h"**  
 2 #include **"irqmp.h"**  
 3 #include **"irqmpreg.h"**  
 4 #include **"irqmp\_tb.h"**  
 5   
 6 **int** sc\_main(**int** argc, **char**\*\* argv) {  
 7   //set generics  
 8   **const** **int** buswidth = 32;  
 9   **const** **int** pindex = 0;  
10   **const** **int** paddr = 0;  
11   **const** **int** pmask = 0xFFF;  
12   **const** **int** ncpu = 2;  
13   **const** **int** eirq = 1;  
14   
15   //define irqmp signals  
16   sc\_core::sc\_signal<**bool**>                      rst(**"rst"**);  
17   sc\_core::sc\_signal<l3\_irq\_out\_type>           irqi[ncpu];  
18   sc\_core::sc\_signal<l3\_irq\_in\_type>            irqo[ncpu];  
19   sc\_core::sc\_signal<sc\_dt::sc\_uint<32> >       apbi\_pirq(**"apbi\_pirq"**),  
20                                                 apbo\_pconfig\_0(**"apbo\_pconfig\_0"**),  
21                                                 apbo\_pconfig\_1(**"apbo\_pconfig\_1"**);  
22   sc\_core::sc\_signal<sc\_dt::sc\_uint<16> >       apbo\_pindex(**"pindex"**);  
23   
24   //instantiate testbench and irqmp  
25   irqmp\_tb<buswidth, pindex, paddr, pmask, ncpu, eirq> irqmp\_tb(**"irqmp\_tb"**);  
26   Irqmp<pindex, paddr, pmask, ncpu, eirq> irqmp\_inst0(**"irqmp"**);  
27   
28   //connect testbench with IRQMP: AMBA bus communication via sockets (TLM)  
29   irqmp\_tb.master\_sock(irqmp\_inst0.bus);  
30   irqmp\_tb.rst(rst);  
31   irqmp\_tb.apbi\_pirq(apbi\_pirq);  
32   **for** (**int** i\_cpu=0; i\_cpu<ncpu; i\_cpu++) {  
33     irqmp\_tb.irqi[i\_cpu](irqi[i\_cpu]);  
34   }  
35   
36   //direct connection of all other signals  
37   irqmp\_inst0.rst(rst);  
38   irqmp\_inst0.apbi\_pirq(apbi\_pirq);  
39   irqmp\_inst0.apbo\_pindex(apbo\_pindex);  
40   irqmp\_inst0.apbo\_pconfig\_0(apbo\_pconfig\_0);  
41   irqmp\_inst0.apbo\_pconfig\_1(apbo\_pconfig\_1);  
42   **for** (**int** i\_cpu=0; i\_cpu<ncpu; i\_cpu++) {  
43     irqmp\_inst0.irqi[i\_cpu](irqi[i\_cpu]);  
44     irqmp\_inst0.irqo[i\_cpu](irqo[i\_cpu]);  
45   }  
46   sc\_core::sc\_start();  
47   **return** 0;  
48 }

# SocWire

## Functionality and Features

The socwire IP provides an AHB/Socwire-bridge based on the AHB2SOCW module created at IDA. The developed module is based on FIXME:SPEC.

The AHB2Socwire module is configured via four registers, which are accessible via an APB bus. Moreover the module works similar to a DMA controller. Transactions are described in transaction descriptors located in a memory at an AHB bus. Data is send over/received from the socwire link according to these descriptors.

## Internal Structure

The socwire IP is delivered in four source files, namely: AHB2Socwire.h, AHB2Socwire.cpp, socw\_defs.h and socw\_gp.h.

The AHB2Socwire.h file provides the class declaration of the actual AHB/Socwire-bridge, while AHB2Socwire.cpp holds its implementation.

The header file socw\_defs.h supplies socwire related data types, methods and constants that might also be useful for applications using the AHB2Socwire module.

The socwire link utilizes its own custom payload object, which is defined in socw\_gp.h.

## Parametrization Options

The original IP provides several generics, which are, as far as reasonable, also modeled in the TLM model as constructor parameters. These parameters are illustrated in table FIXME.

|  |  |  |  |
| --- | --- | --- | --- |
| **Parameter** | **Function** | **Allowed Range** | **Default** |
| nm | SystemC module name | n/a | none |
| paddr | The 12-bit MSB APB address | 0 to 4095 | none |
| pmask | The 12-bit APB address mask | 0 to 4095 | 0 |
| pirq | Interrupt identifier | 0 to 2^32-1 | 0 |
| socw\_datawidth | Width of the socwire link | 16, 32 | 32 |
| socw\_speed | Socwire clock period in nano seconds | 1 to 100 | 10 |
| socw\_after64 | FIXME 6.4 us timeout in ns | 1 to6400 | 64 |
| socw\_after128 | FIXME 12.8 us timeout in ns | 1 to 12800 | 128 |
| disconnect\_detection | FIXME Disconnect detection timeout in ns | 1 to 850 | 85 |

## Interfaces

The module provides several interfaces to communicate with the different parts oft he system. These include the obvious socwire interface, an AHB master and an APB slave interface.

Furthermore an IRQ signal is provided.

From application perspective the APB interface and the IRQ are the only interfaces of interest.

### APB Slave Interface

The APB interface is

An APB slave interface is implemented using the *greenreg* framework in conjunction with *ambasockets*. The APB address space is configured via the constructor parameters *paddr* and *pmask*. The instance name of the greenreg-amba-socket is *apb*.

The AHB2Socwire module provides access to four registers within the assigned APB memory region.

FIXME: add register descriptions

|  |  |
| --- | --- |
| **APB Address Offset** | **Register** |
| 0x00 | Control Register |
| 0x04 | Status Register |
| 0x14 | Transmit descriptor table base address register |
| 0x18 | Receiver descriptor table base address register |

### Interrupt Request

The IRQ signal is a *signalkit* signal of the type *uint32\_t* called *irq*. If an interrupt is generated this signal is driven with the value given as *pirq* to the constructor (default 0) for one clock cycle.

### AHB Master Interface

For reading transaction descriptors and fetching/receiving socwire payload data the AHB2SOCW module consists of an AHB master interface. The amba master socket is called *ahb*.

AHB transactions executed by the AHB2Socwire module are only indirectly influenced from application side by manipulating the module’s control registers.

### Socwire Interface

The socwire interface is realized with a pair of a *green target socket* and a *green initiator socket*. Since transactions over the socwire link are only controlled indirectly using the mentioned descriptors. Applications should never directly access these sockets.

The TX part is realized with the initiator socket called *master\_socket* and has to be bound to a target socket called *slave\_socket*.

The link utilizes the *socw::Cpayload* objects for transmissions:

## Socwire Payload Object

The custom payload object holds the following attributes:

* charType: Type of socwire character.
  + SOCW\_NULL\_CHAR
  + SOCW\_FCT\_CHAR
  + SOCW\_DATA\_CHAR
* data: Pointer to the socwire payload data. Only valid if charType==SOCW\_DATA\_CHAR
* length: Length oft he payload data array.
* eopMarker: Attached EOP marker.
  + SOCW\_NONE\_EOP
  + SOCW\_EOP
  + SOCW\_EEP
* hopc: Contains the number of routing hops the transaction travelled along. Hast o be incremented by every routing element.
* bytec: Contains the number of bytes the receiver was actually able to receive. Has to be initialized with 0 by sender.
* response\_status: Transactions response status
  + SOCW\_OK\_RESP
  + SOCW\_INCOMPLETE\_RESP
  + SOCW\_GENERIC\_ERROR\_RESP
  + SOCW\_CREDIT\_ERROR\_RESP

The attributes can be modified using the following API methods

* bool is\_FCT(): Returns true if charType==SOCW\_FCT\_CHAR
* void set\_FCT(): Sets charType to SOCW\_FCT\_CHAR
* bool is\_NULL(): Returns true if charType==SOCW\_NULL\_CHAR
* void set\_NULL(): Sets charType to SOCW\_NULL\_CHAR
* bool is\_dataChar(): Returns true if charType==SOCW\_DATA\_CHAR
* void set\_dataChar(): Sets charType to SOCW\_DATA\_CHAR
* charTypes\_t get\_charType(): Returns charType.
* void set\_charType(charTypes\_t type): Set charType to type.
* unsigned char\* get\_data\_ptr(): Returns data.
* void set\_data\_ptr(unsigned char\* ptr): Sets data to ptr.
* unsigned int get\_data\_length(): Returns length.
* void set\_data\_length(unsigned int le): Sets length to le.
* bool is\_EOP(): Returns true if eopMarker==SOCW\_EOP.
* bool is\_EEP(): Returns true if eopMarker==SOCW\_EEP.
* eopMarkter\_t get\_eopMarker(): Returns eopMarker.
* void set\_eopMarker(eopMarker\_t marker): Sets eopMarker to marker.
* void inc\_hopc(): Increments hopc by one.
* unsigned int get\_hopc(): Returns hopc.
* oid set\_hopc(unsigned int hops): Sets hopc to hops.
* void inc\_bytec(unsigned int inc): Increments bytec by inc.
* unsigned int get\_bytec(): Returns bytec.
* void set\_bytec(unsigned int count): Sets bytec to count.
* bool is\_response\_ok(): Retunrs true if response\_status>0.
* bool is\_response\_error(): Returns true true if response<=0.
* response\_status\_t get\_response\_status(): Returns response\_status.
* void set\_response\_status(response\_status\_t status): Sets response\_status to status.
* std::string get\_response\_string(): Returns response\_status as printable string.

## Socwire Protocol Implementation

### LT-Level

In the LT implementation one transaction over the link corresponds to one TX descriptor. I.E. the data abstraction level is between the *packet* and *exchange* levels described in the socwire standard.

**Routing:** The data array may start with several bytes of routing information. Socwire uses header deletion, i.e. the used routing information is not forwarded to the next node. To avoid copying of data in this implementation the number of hops, which performed header deletion is counted in the *hopc* payload attribute. Every node receiving a transaction shall ignore the first *hopc* bytes of the payload array, because they are considered deleted.

Every node performing routing is required to increment the *hopc* attribute.

**Sending Data:** Upon activating the transmitter the core starts to fetch the first TX descriptor via the AHB interface. If no descriptor could be read or its enable bit is not set, the TA bit in the status register is set and the TX enable bit in the control reg is cleared.

If a valid descriptor is read the intended payload is copied via AHB to the AHB2Socwire core. Due to the data abstraction level this AHB transfer and the following socwire transfer cannot be processed in parallel, as it should be.

Then the data is transmitted over the socwire link. Afterwards the bytec attribute of the payload object is checked in order to recognize credit errors, which are reported by setting the TE bit in the status register if needed.

Furthermore, the TX descriptor is updated to reflect the status of the transaction.

Eventually the send operation is concluded by checking if a socwire packet was completed by the transaction, which would be indicated by setting the TI bit in the status register. Moreover an IRQ is generated if applicable.

If the transmitter or codec are not disabled, this process is repeated until a non-enabled descriptor is read from memory or an error occurs.

**Receiving Data:** Upon calling of b\_transport first the state of the codec FSM is evaluated. In the *ErrorReset* state nothing actually happens, except the time to transfer the intended data over the link is added to the delay argument.

In all other states the payload object is inspected to hold valid data and the transfer delay is added to the delay argument.

Receiving data via the socwire link works as follows (given the link properly initialized and is in Run state): If no already fetched RX descriptor is available an RX descriptor is fetched via the AHB interface. If this operation fails or the descriptor is disabled the RA bit is set in the status register.

Then as many bytes as offered by the RX descriptor or the transaction object requests – whatever number is lower – is transferred via the AHB bus to an address given by the RX descriptor. The number of successfully received bytes is added to the *bytec* payload object attribute.

If the space offered by the RX descriptor is completely used and/or an end of packet marker is detected the RX descriptor is updated in host memory in order to reflect the updated status of the transaction. If updating the RX descriptor fails the RA bit in the status register is set.

Dependent on the type of the end of packet marker the RI, RE or no bit is set in the status register.

The delay of the AHB transfer might be fully added to the delay which is calculated for the socwire transfer, or completely ignored depending on the slave supporting temporal decoupling or not. Again parallelizing AHB and socwire transfers is not possible due to the coarse data abstraction level.

## Compilation Instructions

For the compilation of the IRQMP unit, a WAF wscript file is provided and integrated in the superordinate build mechanism of the TLM model library of the Hardware-Software SystemC Co-Simulation SoC Validation Platform project.

The libraries required for the compilation are:

FIXME: add lib dependencies

## Example Instantiation

If interrupts are used it has to be made sure a valid value is provided to *pirq* since it defaults to zero, resulting in a IRQ line constantly bound to zero.

FIXME: format source code

#include "AHB2Socwire.h"

// Class instantiaton

CAHB2Socwire u\_ahb2socwire("DUT0", // Name

0xfff, // paddr

0xfff, // pmask

0x4711, // IRQ

32, // Data width

10, // Clock period

64, // after64 timeout

128, // after128 timeout

85); // Disconnect timeout

// Connect sockets

// Connect the APB slave socket to some APB master socket

APB.master\_socket(u\_ahb2socwire.apb);

// Connect the socwire master socket to a socwire slave socket

// (the configuration chosen here shows w.l.o.g. a loopback example)

u\_ahb2socwire.master\_socket(u\_ahb2socwire.slave\_socket);

// Connect the AHB master socket to some AHB slave socket

u\_ahb2socwire.ahb(AHB.slave\_socket);

// Connect the IRQ signal

u\_ahb2socwire.irq(i\_socw\_irq);

# GRLib Plug & Play mechanism

The GRLib PnP support is implemented as a small model of its own, which is located in the ‘models/pnp’ and ‘models/utils’ directories.

All PnP components have to inherit the GrlibDevice class located in ‘models/utils’. This class builds up the PnP register set identifying the device. The contents of the registers have to be passed to the GrlibDevice in the constructor of the child module.

The GrlibPnP module located in ‘models/pnp’ exports all configuration registers and all bank address registers of the GrlibDevices to the memory area specified for the PnP table. The default for this area is 0xFFFFF000 – 0xFFFFFFFF.

To register the GrlibDevices with the GrlibPnP unit, the register\_master (GrlibDevice master) or register\_slave (GrlibDevice slave) function of the GrlibPnP module have to be called in the main function of the system. Their argument is the instance name of the GrlibDevice within the instance of the TLM hardware component.

## Example Instantiation

In the following example, pnpahb and pnpapb are the instance names of the GrlibDevices. These instance names are hard-coded in the Mctrl unit, which is used in this example.

 1 // CREATE MEMORY CONTROLLER  
 2 Mctrl mctrl(**"mctrl\_inst0"**, 0, 0, [...additional constructor params...] 0, 0);  
 3   
 4 // CREATE PLUG & PLAY DEVICE  
 5 GrlibPnP pnp(**"pnp"**);  
 6   
 7 // Register Slave Components at Plug & Play  
 8 pnp.register\_slave(mctrl.pnpahb);  
 9 pnp.register\_slave(mctrl.pnpapb);

# Annex a – Inconsistencies in the GRIP manual

Some details of the intended behavior of the IP cores are not stated clearly in the GRIP manual (LF04). In this annex, a list of such inconsistencies is given to indicate where the TLM IP cores had to be implemented in a consistent way within the scope allowed by the GRIP manual.

## A.1 – MCTRL Memory Controller

1. The GRIP document states (Sect. 58.4, p. 573):

*The SRAM area can be up to 1GB […]. The fifth bank decodes the upper 512 MB (controlled by means of the sdrasel VHDL generic) […].*

Conflict:

In contradiction to that, the allowed range for the *rommask*, *iomask*, and *rammmask* generics is 0 – 0xFFF, representing up to 4GB for each of the address ranges. The allowed range of the *romasel* and *sdrasel* generics is 0 – 31, also representing up to 4GB. *(Sect. 58.15, p. 584)*

Solution:

In the TLM model, the **default** SRAM area is set to 1 GB, but it is parameterizable according to the allowed ranges given in section 58.15 of the GRIP manual (up to 4GB). As – according to the GRIP manual – the size of the 5th SRAM bank is controlled by the *sdrasel* generic, which determines the size of the entire RAM area, the size of the 5th SRAM bank will always be half of the RAM address space (hence filling the entire SDRAM area if no SDRAM is present).

1. The GRIP document states (Sect 58.8, p.576):

*The SDRAM controller supports […] 512MB devices with 8-12 column address bits and up to 13 row address bits. The size of the two banks can be […] 512 MB.*

The size of a single SDRAM bank can be configured to be up to 512MB, resulting in an SDRAM device of 1GB capacity *(Sect. 58.13.2, p. 581)*.

Conflict:

With the given number of address bits (12 x 13), we do not see a possibility to address 512MB of memory (not even in 64 bit mode). The maximum would be:

212 \* 213 \* 64 bit = 212+13+3 Bytes = 228 Bytes = 256 MB

Solution:

In the TLM implementation, no address lines are required. This potential conflict is therefore ignored. The size of the SDRAM banks is configurable in binary steps from 4MB to 512MB.

1. The GRIP document defines (Sect. 58.13.2, p. 581)

*SDRAM COLSZ – “00”=256 […] “11”=4096 when SDRAM BANKSZ = 512MB, 2048 otherwise*

Conflict:

256 – 4096 would refer to 8 – 12 column address bits (then indicating the number of columns, i.e. the row length, not the column size. Again, addressing a 512MB bank would not be possible.

Note: For banks <512MB, COLSZ is fixed to 11 address bits, which would reduce the size of addressable SDRAM banks to 128MB.

Problem statement:

In the TLM implementation the row length can have an impact on the timing of burst accesses that span over two rows. In such a case, both rows would need to be opened and closed again implying an additional amount of delay.

Solution:

Regardless of the potential issue of a lack of address bits, the SDRAM COLSZ field is interpreted to define the row length and is therefore used in the unlikely case of an attempted burst access spanning over two rows.