# connectal Documentation

Release 14.12.6

Jamey Hicks, Myron King, John Ankcorn

## CONTENTS

| 1  | Conr   | nectal Developer's Guide                | 3  |
|----|--------|-----------------------------------------|----|
|    | 1.1    | Connectal Project Structure             | 3  |
|    | 1.2    | Compiling and Running Connectal Project |    |
| 2  | Conr   | nectal BSV Libraries                    | 7  |
|    | 2.1    | Address Generator                       | 7  |
|    | 2.2    | Arith Package                           | 7  |
|    | 2.3    | CtrlMux Package                         | 8  |
|    | 2.4    | HostInterface Package                   | 8  |
|    | 2.5    | Leds Package                            | 9  |
|    | 2.6    | MemPortal Package                       | 9  |
|    | 2.7    | MemreadEngine Package                   | 9  |
|    | 2.8    | MemTypes Package                        | 9  |
|    | 2.9    | MMU Package                             | 13 |
|    | 2.10   | Pipe Package                            | 14 |
|    | 2.11   | Portal Package                          | 18 |
| 3  | Conr   |                                         | 21 |
|    | 3.1    | Simple Example                          | 21 |
| 4  | Indic  | ees and tables                          | 23 |
| Bs | v Pack | kage Index                              | 25 |
| In | dev    |                                         | 27 |

Contents:

CONTENTS 1

2 CONTENTS

**CHAPTER** 

ONE

### **CONNECTAL DEVELOPER'S GUIDE**

# 1.1 Connectal Project Structure

The set of files composing the input to the Connectal toolchain is referred to as a project. A collection of out-of-tree example projects is available at https://github.com/connectal-examples. To illustrate the structure of a project, this chapter uses the example https://github.com/connectal-examples/leds, which can be executed using the Bluesim or Zynq target platforms.

#### 1.1.1 Project Makefile

The top-level Makefile (https://github.com/connectal-examples/leds/blob/master/Makefile) defines parameters building and executing the project. In its simplest form, it specifies which Bluespec interfaces to use as portals, the hardware and software source files, and the libraries to use for the hardware and software compilation:

```
INTERFACES = LedControllerRequest
BSVFILES = LedController.bsv Top.bsv
CPPFILES= testleds.cpp
NUMBER_OF_MASTERS =0
include \$(CONNECTALDIR)/Makefile.connectal
```

INTERFACES is a list of names of BSV interfaces which may be used to communicate between the HW and SW componentsy. In addition to user-defined interfaces, there are a wide variety of interfaces defined in Connectal libraries which may be included in this list.

BSVFILES is a list of bsv files containing interface definitions used to generate portals and module definitions used to generate HW components. Connectal bsv libraries can be used without being listed explicitly.

CPPFILES is a list of C/C++ files containing software components and main. The Connectal C/C++ libraries can be used without being listed explicitly.

NUMBER\_OF\_MASTERS is used to designate the number of host bus masters the hardware components will instantiate. For PCIe-based platforms, this value can be set to 0 or 1, while on Zynq-based platforms values from 0 to 4 are valid.

CONNECTALDIR must be set so that the top-level Connectal makefile can be included. This brings in the default definitions of all project build parameters as well as the Connectal hardware and software libraries. When running the toolchain on AWS, this varible is set automatically in the build environment. (hyper-ref[compiling\_a\_project]{Section~ref{compiling\_a\_project}})

#### 1.1.2 Project Source

#### **Interface Definitions**

label{interface definitions}

When generating portals, the Connectal interface compiler searches the Connectal bsv libraries and the files listed in BSVFILES for definitions of all the interfaces listed in INTERFACES. If an the definition of a listed interfaces is not found, an error is reported the the compilation aborts. The interfaces in this list must be composed exclusively of Action methods. Supported method argument types are Bit#(n),Bool,Int#(32),UInt#(32),Float,Vector#(t),enum,andstruct.

#### **Software**

The software in a Connectal project consists of at least one C++ file which instantiates the generated portal wrappers and proxies and implements main(). The following source defines the SW component of the example, which simply toggles LEDs on the Zedboard (url{https://github.com/connectal-examples/leds/blob/master/testleds.cpp}):

```
#include <unistd.h>
#include "LedControllerRequest.h"
#include "GeneratedTypes.h"
int main(int argc, const char **argv)
{
    LedControllerRequestProxy *device =
        new LedControllerRequestProxy(IfcNames_LedControllerRequest);
    for (int i = 0; i < 20; i++) {
        device->setLeds(10, 10000);
        sleep(1);
        device->setLeds(5, 10000);
        sleep(1);
    }
}
```

The makefile listed LedControllerRequest as the only communication interface. The generated proxies and wrappers for this interface are in LedControllerRequest.h which is included, along with C++ implementations of all additional interface types in GeneratedTypes.h. Line 9 instantiates the proxy through which the software invokes the hardware methods (hyperref[flow\_control]{Section~ref{flow\_control}}).

#### 1.1.3 Hardware

Connectal projects typically have at least one BSV file containing interface declarations and module definitions. The implementation of the interfaces and all supporting infrastructure is standard BSV. Interfaces being used as portals are subject to the type restrictions described earlier (hyperref[interface\_definitions]{Section~ref{interface\_definitions}}).

#### Top.bsv

In Top.bsv (https://github.com/connectal-examples/leds/blob/master/Top.bsv), the developer instantiates all hardware modules explicitly. Interfaces which can be invoked through portals need to be connected to the generated wrappers and proxies. To connect to the host processor bus, a parameterized standard interface is used, making it easy to synthesize the application for different CPUs or for simulation:

```
// Connectal Libraries
import CtrlMux::*;
import Portal::*;
```

```
import Leds::*;
import MemTypes::*;
import MemPortal::*;
import HostInterface::*;
import LedControllerRequest::*;
import LedController::*;
typedef enum {LedControllerRequestPortal} IfcNames deriving (Eq,Bits);
module mkConnectalTop(StdConnectalTop#(PhysAddrWidth));
   LedController ledController <- mkLedControllerRequest();</pre>
   LedControllerRequestWrapper ledControllerRequestWrapper <-
      mkLedControllerRequestWrapper(LedControllerRequestPortal,
      ledController.request);
   Vector#(1,StdPortal) portals;
   portals[0] = ledControllerRequestWrapper.portalIfc;
   let ctrl_mux <- mkSlaveMux(portals);</pre>
   interface interrupt = getInterruptVector(portals);
   interface slave = ctrl_mux;
   interface masters = nil;
   interface leds = ledController.leds;
endmodule
```

Like the SW components, the HW begins by importing the generated wrappers and proxies corresponding to the interfaces listed in the project Makefile. The user-defined implementation of the LedControllerRequest interface is instantiated on line 14, and wrapped on line 15. This wrapped interface is connected to the bus using the library module mkSlaveMux on line 21 so it can be invoked from the software. At the end of the module definition, the top-level interface elements must be connected. A board-specific top-level module will include this file, instantiate mkConnectalTop and connect the interfaces to the actual peripherals. The name of the file must be Top.bsv and the name of the module must be mkConnectalTop.

The Bluespec compiler generates a Verilog module from the top level BSV module, in which the methods of exposed interfaces are implemented as Verilog ports. Those ports are associated to physical pins on the FPGA using a physical constraints file. If CPU specific interface signals are needed by the design (for example, extra clocks that are generated by the PCIe core), then an optional CPU-specific interface can also be used. If the design uses multiple clock domains or additional pins on the FPGA, those connections are also made here by exporting a 'Pins' interface (hyperref[host\_interface]{Section~ref{host\_interface}}).

# 1.2 Compiling and Running Connectal Project

## 1.2.1 Compiling on ConnectalBuild

The Connectal toolchain can be run on ConnectalBuild using the following Buildbot web interface: http://connectalbuild.qrclab.com/projects.

| → C                                                                                                      | ☆ :   |
|----------------------------------------------------------------------------------------------------------|-------|
| Home - Waterfall Grid T-Grid Console Builders Recent Builds Buildslaves Changesources - JSUN API - About | login |
| Welcome to the Connectal Buildbot for                                                                    |       |
| the Connectal project!                                                                                   |       |
|                                                                                                          |       |
| Project Name:                                                                                            |       |
| Project Repo: git://github.com/ <username>/<repo>.git</repo></username>                                  |       |
| Path:                                                                                                    |       |
| Branch:                                                                                                  |       |
| Revision:                                                                                                |       |
| Bluesim: ☐ Zedboard: ☐ ZC706: ☐ VC707: ☐                                                                 |       |
| Board IP Addr:                                                                                           |       |
| Add                                                                                                      |       |
| This and other pages can be everyidden and customized                                                    |       |
| This and other pages can be overridden and customized.                                                   |       |
|                                                                                                          |       |

Before submitting a project, you must sign in using your github credentials. We do not store credentials, but pass them through to github. Next, enter a name for the project, which will be used for subsequent build requests through the Buildbot web interface. The project must be in a publicly accessible git-hub repository, whose Repo location is entered beginning with git:// as follows git://github.com/connectal-examples/leds.git. If the project makefile is not in the root directory of the repository, enter its relative path in the 'Path' field of the form. If a particular branch or revision number are desired, enter these as well. Check the button to select the build target. If you have selected a zynq-based platform and would like the tool-chain to automatically program the device and execute the design as its final step, then enter the IP address of your board. This works only because adb doesn't require authentication. SSH keys required to run on PCIe-based platforms are not currently supported. Finally, don't forget to click 'Add'. If the project name has already been used, you will be prompted to enter a new one at this point.

#### 1.2.2 Compiling Locally

Before compiling a project locally, you will need to install the toolchain. After setting the CONNECTALDIR to the root of the connectal source tree, enter the command make

## 1.2.3 Running the Design

**CHAPTER** 

**TWO** 

#### CONNECTAL BSV LIBRARIES

#### 2.1 Address Generator

One of the common patterns that leads to long critical paths in designs on the FPGA are counters and comparisons against counters. This package contains a module for generating the sequence of addresses used by a memory read or write burst, along with a field indicating the last beat of the burst.

```
struct AddressGenerator::AddrBeat#(numeric type addrWidth)
```

```
\begin{tabular}{l} \textbf{addr} & \to Bit\#(addrWidth) \\ & The address for this beat of the request. \\ \begin{tabular}{l} \textbf{bc} & \to Bit\#(BurstLenSize) \\ \end{tag} & \to Bit\#(MemTagSize) \\ \end{tagthered}
```

```
\begin{tabular}{ll} \textbf{request} \to Put\#(PhysMemRequest\#(addrWidth)) \\ The interface for requesting a sequence of addresses. \\ \end{tabular}
```

```
addrBeat → Get#(AddrBeat#(addrWidth))
```

The interface for getting the address beats of the burst. There is one pipeline cycle from the reuqest to the first address beat.

 $\label{eq:module} \textbf{ModressGenerator::mkAddressGenerator} \rightarrow (AddressGenerator\#(addrWidth,\,dataWidth)\\ Instantiates an address generator.$ 

# 2.2 Arith Package

The Arith package implements some functions that correspond to infix operators.

```
function Arith::booland (Bool \, xI, Bool \, x2) \to Bool Returns logical "and" of inputs. Named to avoid conflict with the Verilog keyword "and". function Arith::boolor (Bool \, xI, Bool \, x2) \to Bool Returns logical "or" of inputs. Named to avoid conflict with the Verilog keyword "or". function Arith::eq (a \, xI, a \, x2)) \to Bool function Arith::add (a \, xI, a \, x2) \to a
```

Returns sum of inputs. Requires Arith#(a).

**function** Arith::mul  $(a x1, a x2) \rightarrow a$ 

Returns product of inputs. Requires Arith#(a).

**function** Arith::rshift (Bit#(b) x1, Integer i)  $\rightarrow$  Bit#(b)

Returns input right shifted by i bits.

**function** Arith::a) **vadd** ( $Vector\#(n, a) \times 1$ ,  $Vector\#(n, a) \times 2$ )  $\rightarrow$  Vector $\#(n, a) \times 2$ 

Returns sum of input vectors.

**function** Arith::a) **vmul** ( $Vector\#(n, a) \times 1$ ,  $Vector\#(n, a) \times 2$ )  $\rightarrow$  Vector $\#(n, a) \times 1$ ,  $Vector\#(n, a) \times 2$ 

Returns element-wise product of input vectors.

**function** Arith::Bit#(b)) vrshift(Vector# $(n, Bit#(b)) x1, Integer i) <math>\rightarrow$  Vector#(n, Bit#(b)) x1, Integer i)

Right shifts the elements of the input vector by i bits.

## 2.3 CtrlMux Package

 $\begin{tabular}{ll} \textbf{module} \ \texttt{CtrlMux::mkInterruptMux} \ (\textit{Vector\#(numPortals}, \ \textit{MemPortal\#(aw, \ dataWidth)}) \ \textit{portals}) \ \rightarrow \\ & (\texttt{ReadOnly\#(Bool)}) \end{tabular}$ 

Used by BsimTop, PcieTop, and ZynqTop. Takes a vector of MemPortals and returns a boolean indicating whether any of the portals has indication method data available.

Takes a vector of MemPortals and returns a PhysMemSlave combining them.

## 2.4 HostInterface Package

The HostInterface package provides host-specific typedefs and interfaces.

#### 2.4.1 Host-Specific Constants

typedef HostInterface::DataBusWidth

Width in bits of the data bus connected to host shared memory.

typedef HostInterface::PhysAddrWidth

Width in bits of physical addresses on the data bus connected to host shared memory.

typedef HostInterface::NumberOfMasters

Number of memory interfaces used for connecting to host shared memory.

## 2.4.2 Host-Specific Interfaces

interface HostInterface::BsimHost

Host interface for the bluesim platform

interface HostInterface::PcieHost

Host interface for PCIe-attached FPGAs such as vc707 and kc705

interface HostInterface::ZynqHost

Host interface for Zyng FPGAs such as zedboard, zc702, zc706, and zybo.

The Zc706 is a ZynqHost even when it is plugged into a PCIe slot.

# 2.5 Leds Package

## 2.6 MemPortal Package

#### 2.6.1 mkMemPortal Module

```
\begin{tabular}{ll} \textbf{module} \ \texttt{MemPortal}: \textbf{:mkMemPortal} \ (\textit{Bit\#}(\textit{slaveDataWidth}) \ \textit{ifcId}, \ \textit{PipePortal\#}(\textit{numRequests}, \ \textit{numIndications}, \ \textit{slaveDataWidth}) \ \textit{portal}) \ \rightarrow \ (\texttt{MemPortal\#}(\textit{slaveAddrWidth}, \ \textit{slaveDataWidth}) \ \\ \textbf{Takes an interface identifier and a PipePortal and returns a MemPortal}. \end{tabular}
```

# 2.7 MemreadEngine Package

```
\begin{tabular}{ll} \textbf{module} & \texttt{MemreadEngine::mkMemreadEngine} (\textbf{MemreadEngineV} (\textit{dataWidth}, & \textit{cmdQDepth}, & \textit{num-Servers}) \\ & \texttt{Creates a MemreadEngine with default 256 bytes of buffer per server.} \\ \\ \textbf{module} & \texttt{MemreadEngine::mkMemreadEngineBuff} (\textit{Integer bufferSizeBytes}) & \rightarrow & (\texttt{Memread-EngineV\#(dataWidth, cmdQDepth, numServers})} \\ & \texttt{Creates a MemreadEngine with the specified buffer size.} \\ \end{tabular}
```

# 2.8 MemTypes Package

#### 2.8.1 Constants

```
typedef MemTypes::Bit#(32) SGLId
typedef MemTypes::44 MemOffsetSize
typedef MemTypes::6 MemTagSize
typedef MemTypes::8 BurstLenSize
typedef MemTypes::32 MemServerTags
```

#### 2.8.2 Data Types

```
struct MemTypes::PhysMemRequest# (numeric type addrWidth)
    A memory request containing a physical memory address
addr → Bit#(addrWidth)
    Physical address to read or write
```

2.5. Leds Package 9

```
burstLen → Bit#(BurstLenSize)
```

Length of read or write burst, in bytes. The number of beats of the request will be the burst length divided by the physical width of the memory interface.

```
tag \rightarrow Bit\#(MemTagSize)
```

```
struct MemTypes::MemRequest
```

A logical memory read or write request. The linear offset of the request will be translated by an MMU according to the specified scatter-gather list.

```
\mathtt{sglId} \to \mathrm{SGLId}
```

Indicates which scatter-gather list the MMU should use when translating the address

```
offset → Bit#(MemOffsetSize)
```

Linear byte offset to read or write.

```
burstLen → Bit#(BurstLenSize)
```

Length of read or write burst, in bytes. The number of beats of the request will be the burst length divided by the physical width of the memory interface.

```
\texttt{tag} \rightarrow Bit\#(MemTagSize)
```

```
struct MemTypes::MemData#(numeric type dsz)
```

One beat of the payload of a physical or logical memory read or write request.

```
data \rightarrow Bit\#(dsz)
```

One data beat worth of data.

```
tag \rightarrow Bit\#(MemTagSize)
```

Indicates to which request this beat belongs.

```
last \rightarrow Bool
```

Indicates that this is the last beat of a burst.

## 2.8.3 Physical Memory Clients and Servers

```
interface MemTypes::PhysMemSlave (numeric type addrWidth, numeric type dataWidth)
    read_server → PhysMemReadServer#(addrWidth, dataWidth)
    write_server → PhysMemWriteServer#(addrWidth, dataWidth)
interface MemTypes::PhysMemMaster (numeric type addrWidth, numeric type dataWidth)
    read_client → PhysMemReadClient#(addrWidth, dataWidth)
    write_client → PhysMemWriteClient#(addrWidth, dataWidth)
interface MemTypes::PhysMemReadClient (numeric type asz, numeric type dsz)

readReq → Get#(PhysMemRequest#(asz))
    readData → Put#(MemData#(dsz))
interface MemTypes::PhysMemWriteClient (numeric type asz, numeric type dsz)

writeReq → Get#(PhysMemRequest#(asz))
    writeData → Get#(MemData#(dsz))
```

```
writeDone → Put#(Bit#(MemTagSize))
interface MemTypes::PhysMemReadServer (numeric type asz, numeric type dsz)
     readReq \rightarrow Put\#(PhysMemRequest\#(asz))
     readData \rightarrow Get\#(MemData\#(dsz))
interface MemTypes::PhysMemWriteServer (numeric type asz, numeric type dsz)
     writeReq → Put#(PhysMemRequest#(asz))
     writeData → Put#(MemData#(dsz))
     writeDone → Get#(Bit#(MemTagSize))
2.8.4 Memory Clients and Servers
```

# interface MemTypes::MemReadClient (numeric type dsz)

```
readReq \rightarrow Get\#(MemRequest)
      readData \rightarrow Put\#(MemData\#(dsz))
interface MemTypes::MemWriteClient (numeric type dsz)
      writeReq → Get#(MemRequest)
      writeData \rightarrow Get\#(MemData\#(dsz))
      \textbf{writeDone} \rightarrow Put\#(Bit\#(MemTagSize))
interface MemTypes::MemReadServer (numeric type dsz)
      readReq \rightarrow Put\#(MemRequest)
      \textbf{readData} \rightarrow Get\#(MemData\#(dsz))
interface MemTypes::MemWriteServer (numeric type dsz)
      writeReq → Put#(MemRequest)
      writeData \rightarrow Put\#(MemData\#(dsz))
      writeDone \rightarrow Get\#(Bit\#(MemTagSize))
```

#### 2.8.5 Memory Engine Types

```
struct MemTypes::MemengineCmd
```

A read or write request for a MemreadEngine or a MemwriteEngine. Memread and Memwrite engines will issue one or more burst requests to satisfy the overall length of the request.

```
sglid \rightarrow SGLId
```

Which scatter gather list the MMU should use to translate the addresses

```
base \rightarrow Bit\#(MemOffsetSize)
```

Logical base address of the request, as a byte offset

```
burstLen → Bit#(BurstLenSize)
           Maximum burst length, in bytes.
     len \rightarrow Bit\#(32)
           Number of bytes to transfer. Must be a multiple of the data bus width.
     tag \rightarrow Bit\#(MemTagSize)
           Identifier for this request.
2.8.6 Memory Engine Interfaces
interface MemTypes::MemwriteServer (numeric type dataWidth)
     cmdServer → Server#(MemengineCmd,Bool)
```

```
dataPipe → PipeIn#(Bit#(dataWidth))
interface MemTypes:: MemwriteEngineV (numeric type dataWidth, numeric type cmdQDepth, numeric
                                            type numServers)
     \textbf{dmaClient} \rightarrow MemWriteClient\#(dataWidth)
     writeServers \rightarrow Vector\#(numServers, Server\#(MemengineCmd, Bool))
     dataPipes → Vector#(numServers, PipeIn#(Bit#(dataWidth)))
     write_servers → Vector#(numServers, MemwriteServer#(dataWidth))
typedef MemTypes::MemwriteEngineV#(dataWidth,cmdQDepth,1) MemwriteEngine#(numeric type dataWidth,cmdQDepth,1)
interface MemTypes::MemreadServer (numeric type dataWidth)
     cmdServer → Server#(MemengineCmd,Bool)
     \texttt{dataPipe} \rightarrow PipeOut\#(Bit\#(dataWidth))
interface MemTypes:: MemreadEngineV (numeric type dataWidth, numeric type cmdQDepth, numeric
                                           type numServers)
     dmaClient \rightarrow MemReadClient\#(dataWidth)
```

 $readServers \rightarrow Vector\#(numServers, Server\#(MemengineCmd, Bool))$ dataPipes → Vector#(numServers, PipeOut#(Bit#(dataWidth)))

 $\textbf{read\_servers} \rightarrow Vector\#(numServers, MemreadServer\#(dataWidth))$ 

typedef MemTypes::MemreadEngineV#(dataWidth,cmdQDepth,1) MemreadEngine#(numeric type dataWidth

#### 2.8.7 Memory Traffic Interfaces

```
interface MemTypes::DmaDbg
     getMemoryTraffic → ActionValue#(Bit#(64))
     dbg \rightarrow ActionValue\#(DmaDbgRec)
```

#### 2.8.8 Connectable Instances

```
instance MemTypes::Connectable (MemReadClient#(dsz), MemReadServer#(dsz))
instance MemTypes::Connectable (MemWriteClient#(dsz), MemWriteServer#(dsz))
instance MemTypes::Connectable (PhysMemMaster#(addrWidth, busWidth), PhysMemSlave#(addrWidth, busWidth))
instance MemTypes::Connectable (PhysMemMaster#(32, busWidth), PhysMemSlave#(40, busWidth))
```

## 2.9 MMU Package

```
typedef MMU::32 MaxNumSGLists
typedef MMU::Bit#(TLog#(MaxNumSGLists)) SGListId
typedef MMU::12 SGListPageShift0
typedef MMU::16 SGListPageShift4
typedef MMU::20 SGListPageShift8
typedef MMU::Bit#(TLog#(MaxNumSGLists)) RegionsIdx
typedef MMU::8 IndexWidth
```

#### 2.9.1 Address Translation

```
struct MMU::ReqTup
      Address translation request type
      id \rightarrow SGListId
            Which SGList to use.
      off \rightarrow Bit\#(MemOffsetSize)
            The address to translate.
interface MMU : :MMU (numeric type addrWidth)
      An address translator
      request \rightarrow MMURequest
            The interface of the MMU that is exposed to software as a portal.
      \texttt{addr} \rightarrow Vector\#(2,Server\#(ReqTup,Bit\#(addrWidth)))
            The address translation servers
module MMU::mkMMU (Integer
                                                                     MMUIndication
                                                                                         mmuIndication)
                                    iid.
                                            Bool
                                                    bsimMMap,
                         (MMU#(addrWidth)
      Instantiates an address translator that stores a scatter-gather list to define the logical to physical address mapping.
```

### 2.9.2 Multiple Address Translators

Parameter bsimMMAP ??

```
interface MMU:: MMUAddrServer (numeric type addrWidth, numeric type numServers) Used by mkMemServer to share an MMU among multiple memory interfaces.
```

Parameter iid is the portal identifier of the MMURequest interface.

2.9. MMU Package 13

# 2.10 Pipe Package

The Pipe package is modeled on Bluespec, Inc's PAClib package. It provides functions and modules for composing pipelines of operations.

#### 2.10.1 Pipe Interfaces

```
interface Pipe::PipeIn(type a)
      Corresponds to the input interface of a FIFOF.
      eng (a \ v) \rightarrow Action
      notFull \rightarrow Bool
interface Pipe::PipeOut (type a)
      Corresponds to the output interface of a FIFOF.
      \textbf{first} \to a
      deq \rightarrow Action
      notEmpty \rightarrow Bool
typeclass Pipe::ToPipeIn(type a, type b)
      function toPipeIn (b \ in) \rightarrow PipeIn#(a)
            Returns a PipeIn to the object "in" with no additional buffering.
typeclass Pipe::ToPipeOut (type a, type b)
      function toPipeOut (b \ in) \rightarrow PipeOut\#(a)
            Returns a PipeOut from the object "in" with no additional buffering.
typeclass Pipe:: MkPipeIn (type a, type b)
      module mkPipeIn (b \ in) \rightarrow (PipeIn\#(a))
            Instantiates a module whose interface is a PipeIn to the input parameter "in". Includes a FIFO buffering
            stage.
typeclass Pipe::MkPipeOut (type a, type b)
      module mkPipeOut(b in) \rightarrow (PipeOut#(a))
            Instantiates a module whose interface is PipeOut from the input parameter "in". Includes a FIFO buffering
            stage.
instance Pipe::ToPipeIn (a, FIFOF#(a))
      Converts a FIFOF to a PipeIn.
```

```
instance Pipe::ToPipeOut (a, function a pipefn())
     Converts a function to a PipeOut.
instance Pipe::ToPipeOut (a, Reg#(a))
     Converts a register to a PipeOut.
instance Pipe::ToPipeIn (Vector\#(m, a), Gearbox\#(m, n, a))
     Converts a Gearbox to a PipeOut.
instance Pipe::ToPipeOut (a, FIFOF#(a))
     Converts a FIFOF to a PipeOut.
instance Pipe::ToPipeOut (Vector\#(n, a), MIMO\#(k, n, sz, a))
     Converts a MIMO to a PipeOut.
instance Pipe::ToPipeOut (Vector\#(n, a), Gearbox\#(m, n, a))
     Converts a Gearbox to a PipeOut.
instance Pipe::MkPipeOut (a, Get#(a))
     Instantiates a pipelined PipeOut from a Get interface.
instance Pipe::MkPipeIn (a, Put#(a))
     Instantiates a pipelined PipeIn to a Put interface.
2.10.2 Get and Put Pipes
instance Pipe::ToGet (PipeOut #(a), a)
instance Pipe::ToPut (PipeIn \#(a), a)
2.10.3 Connectable Pipes
instance Pipe::Connectable(PipeOut#(a), Put#(a))
instance Pipe::Connectable(PipeOut#(a), PipeIn#(a))
2.10.4 Mapping over Pipes
function Pipe::toCountedPipeOut (Reg\#(Bit\#(n)) r, PipeOut\#(a) pipe) \rightarrow PipeOut\#(a)
function Pipe::zipPipeOut (PipeOut\#(a) ina, PipeOut\#(b) inb) \rightarrow PipeOut\#(Tuple2\#(a,b))
     Returns a PipeOut whose elements are 2-tuples of the elements of the input pipes.
function Pipe::mapPipe (function b f(a \ av), PipeOut#(a) apipe) \rightarrow PipeOut#(b)
     Returns a PipeOut that maps the function f to each element of the input pipes with no buffering.
module Pipe::mkMapPipe (function b f(a av), PipeOut#(a) apipe) \rightarrow (PipeOut#(b)
     Instantiates a PipeOut that maps the function f to each element of the input pipes using a FIFOF for buffering.
function Pipe::mapPipeIn (function b f(a \ av), PipeIn#(b) apipe) \rightarrow PipeIn#(a)
     Returns a PipeIn applies the function f to each value that is enqueued.
2.10.5 Reducing Pipes
```

**function** Pipe::unvectorPipeOut ( $PipeOut\#(Vector\#(1, a)) in) \rightarrow PipeOut\#(a)$ 

2.10.6 Functions on Pipes of Vectors

#### 2.10. Pipe Package 15

#### 2.10.7 Funneling and Unfunneling

```
module Pipe::mkFunnel (PipeOut\#(Vector\#(mk, a)) in) \rightarrow (PipeOut\#(Vector\#(m, a))
```

Returns k Vectors of m elements for each Vector#(mk,a) element of the input pipe.

**module** Pipe::mkFunnel1 ( $PipeOut\#(Vector\#(k, a)) in) \rightarrow (PipeOut\#(a))$ 

Sames as mkFunnel, but returns k singleton elements for each vector element of the input pipe.

**module** Pipe::mkFunnelGB1 (Clock slowClock, Reset slowReset, Clock fastClock, Reset fastReset, Pipe-Out#(Vector#(k, a)) in)  $\rightarrow$  (PipeOut#(a))

Same as mkFunnel1, but uses a Gearbox with a 1 to k ratio.

**module** Pipe::mkUnfunnel( $PipeOut\#(Vector\#(m, a))in) \rightarrow (PipeOut\#(Vector\#(mk, a)))$ 

The dual of mkFunnel. Consumes k elements from the input pipe, each of which is an m-element vector, and returns an mk-element vector.

**module** Pipe::mkUnfunnelGB (Clock slowClock, Reset slowReset, Clock fastClock, Reset fastReset, Pipe-Out#(Vector#(1, a)) in)  $\rightarrow$  (PipeOut#(Vector#(k, a))

The same as mkUnfunnel, but uses a Gearbox with a 1-to-k.

**module** Pipe::mkRepeat (UInt#(n) repetitions, PipeOut#(a) inpipe)  $\rightarrow$  (PipeOut#(a)

Returns a PipeOut which repeats each element of the input pipe the specified number of times.

#### 2.10.8 Fork and Join

Fork and Join with limited scalability

**module** Pipe::mkForkVector(PipeOut#(a) inpipe)  $\rightarrow$  (Vector#(n, PipeOut#(a))

Replicates each element of the input pipe to each of the output pipes. It uses a FIFOF per output pipe.

**module** Pipe::mkSizedForkVector(Integer size, PipeOut#(a) inpipe)  $\rightarrow$  (Vector#(n, PipeOut#(a)) Used a SizedFIFOF for each of the output pipes.

**module** Pipe::mkJoin (function c f(a av, b bv), PipeOut#(a) apipe, PipeOut#(b) bpipe)  $\rightarrow$  (PipeOut#(c) Returns a PipeOut that applies the function f to the elements of the input pipes, with no buffering.

**module** Pipe::mkJoinBuffered (function c f(a av, b bv), PipeOut#(a) apipe, PipeOut#(b) bpipe)  $\rightarrow$  (PipeOut#(c)

Returns a PipeOut that applies the function f to the elements of the input pipes, using a FIFOF to buffer the output.

**module** Pipe::mkJoinVector (function b f(Vector#(n, a) av), Vector#(n, PipeOut#(a)) apipes)  $\rightarrow$  (PipeOut#(b)

Same as mkJoin, but operates on a vector of PipeOut as input.

#### 2.10.9 Funnel Pipes

Fork and Join with tree-based fanout and fanin for scalability.

These are used by MemreadEngine and MemwriteEngine.

```
typedef Pipe::Vector#(j,PipeOut#(a)) FunnelPipe#(numeric type j, numeric type k, type a, nutypedef Pipe::Vector#(k,PipeOut#(a)) UnFunnelPipe#(numeric type j, numeric type k, type a, nutypedef Pipe::Vector#(k,PipeOut#(a))
```

 $\textbf{typeclass} \ \texttt{Pipe::FunnelPipesPipelined} \ (\textit{numeric type } j, \textit{numeric type } k, \textit{type } a, \textit{numeric type } bpc)$ 

**module mkFunnelPipesPipelined** (Vector#(k, PipeOut#(a))  $in) \rightarrow$  (FunnelPipe#(j,k,a,bpc)

```
module mkFunnelPipesPipelinedRR (Vector\#(k, PipeOut\#(a)) in, Integer\ c) \rightarrow (Fun-thermologies)
                                                                                                                                           nelPipe#(j,k,a,bpc)
                module mkUnFunnelPipesPipelined (Vector\#(j, PipeOut\#(Tuple2\#(Bit\#(TLog\#(k)), a))) in) <math>\rightarrow
                                                                                                                                           (UnFunnelPipe#(j,k,a,bpc)
                module mkUnFunnelPipesPipelinedRR (Vector\#(j, PipeOut\#(a)) in, Integer\ c) \rightarrow (UnFun-bullet)
                                                                                                                                                   nelPipe#(j,k,a,bpc)
instance Pipe::FunnelPipesPipelined(1, 1, a, bpc)
instance Pipe::FunnelPipesPipelined(1, k, a, bpc)
module Pipe::mkUnFunnelPipesPipelinedInternal(Vector#(1,
                                                                                                                                                                                                                                                                                          Pipe-
                                                                                                                                                                                  Out\#(Tuple2\#(Bit\#(TLog\#(k)),
                                                                                                                                                                                                                                                                             a))) in)
                                                                                                                                                                                  \rightarrow (UnFunnelPipe#(1,k,a,bpc)
module Pipe::mkFunnelPipes (Vector\#(mk, PipeOut\#(a)) ins) \rightarrow (Vector\#(m, PipeOut\#(a)))
module Pipe: :mkFunnelPipes1 (Vector\#(k, PipeOut\#(a)) ins) \rightarrow (PipeOut\#(a))
\textbf{module} \ \texttt{Pipe::mkUnfunnelPipes} \ (\textit{Vector\#}(m,\textit{PipeOut\#}(a)) \ \textit{ins}) \ \rightarrow (\texttt{Vector\#}(mk,\textit{PipeOut\#}(a)) \ \rightarrow (\texttt{Vec
module Pipe::mkPipelinedForkVector(PipeOut#(a)
                                                                                                                                                                                 inpipe,
                                                                                                                                                                                                                                                                                 (UnFun-
                                                                                                                                                                                                                Integer
                                                                                                                                       nelPipe#(1,k,a,bpc)
2.10.10 Delimited Pipes
interface Pipe::FirstLastPipe(type a)
                A pipe whose elements two-tuples of boolean values indicating first and last in a series. The ttype a indicates
                the type of the counter used.
                pipe → PipeOut#(Tuple2#(Bool,Bool))
                               The pipe of delimited elements
                start(a count) \rightarrow Action
                               Starts the series of count elements
module Pipe::mkFirstLastPipe → (FirstLastPipe#(a)
                Creates a FirstLastPipe.
struct Pipe::RangeConfig#(type a)
                The base, limit and step for mkRangePipeOut.
                {\tt xbase} 	o a
                	extbf{xlimit} 	o a
                \mathbf{xstep} \to a
interface Pipe::RangePipeIfc(type a)
                pipe \rightarrow PipeOut\#(a)
                isFirst \rightarrow Bool
                isLast \rightarrow Bool
                start(RangeConfig\#(a) cfg) \rightarrow Action
module Pipe::mkRangePipeOut → (RangePipeIfc#(a)
                Creates a Pipe of values from xbase to xlimit by xstep. Used by Memread.
```

2.10. Pipe Package

# 2.11 Portal Package

### 2.11.1 PipePortal Interface

```
\begin{tabular}{l} \textbf{interface} \ \texttt{Portal}: \textbf{:PipePortal} \ (numeric \ type \ numRequests, \ numeric \ type \ numIndications, \ numeric \ type \ slaveDataWidth) \\ \textbf{messageSize} \ (Bit\#(16) \ methodNumber) \ \rightarrow \ Bit\#(16) \\ \textbf{Returns} \ the \ message \ size \ of \ the \ methodNumber \ method \ of \ the \ portal. \\ \textbf{requests} \ \rightarrow \ Vector\#(numRequests, PipeIn\#(Bit\#(slaveDataWidth)))) \\ \textbf{indications} \ \rightarrow \ Vector\#(numIndications, PipeOut\#(Bit\#(slaveDataWidth)))) \\ \end{tabular}
```

#### 2.11.2 MemPortal Interface

### 2.11.3 ShareMemoryPortal Interface

## 2.11.4 ConnectalTop Interface

```
interface Portal::ConnectalTop (numeric type addrWidth, numeric type dataWidth, type pins, numeric type numMasters)

Interface ConnectalTop is the interface exposed by the top module of a Connectal hardware design.

slave \rightarrow PhysMemSlave#(32,32)

masters \rightarrow Vector#(numMasters,PhysMemMaster#(addrWidth, dataWidth))

interrupt \rightarrow Vector#(16,ReadOnly#(Bool))

leds \rightarrow LEDS

pins \rightarrow pins
```

## 2.11.5 StdConnectalTop Typedef

 $\begin{tabular}{ll} \textbf{typedef} \ \texttt{Portal::StdConnectalTop} \ (numeric & type & addrWidth) & \rightarrow & Connectal-Top\#(addrWidth,64,Empty,0) \\ \hline \\ \ & \begin{tabular}{ll} \textbf{Top\#(addrWidth,64,Empty,0)} \\$ 

Type StdConnectalTop indicates a Connectal hardware design with no user defined pins and no user of host shared memory. The "pins" interface is Empty and the number of masters is 0.

Type StdConnectalDmaTop indicates a Connectal hardware design with no user defined pins and a single client of host shared memory. The "pins" interface is Empty and the number of masters is 1.

2.11. Portal Package

| CHAPTER |
|---------|
| THREE   |

# **CONNECTAL EXAMPLES**

# 3.1 Simple Example

## **CHAPTER**

# **FOUR**

# **INDICES AND TABLES**

- genindex
- modindex
- search

# а AddressGenerator,7 Arith, 7 С CtrlMux, 8 h HostInterface, 8 Leds, 9m MemPortal, 9 ${\tt MemreadEngine}, 9$ MemTypes, 9 MMU, 13 р Pipe, 14 Portal, 18

26 Bsv Package Index

| Symbols  12 SGListPageShift0 (typedef in package MMU), 13 16 SGListPageShift4 (typedef in package MMU), 13 20 SGListPageShift8 (typedef in package MMU), 13 32 MaxNumSGLists (typedef in package MmU), 13 32 MemServerTags (typedef in package MemTypes), 9 44 MemOffsetSize (typedef in package MemTypes), 9 6 MemTagSize (typedef in package MemTypes), 9 8 BurstLenSize (typedef in package MemTypes), 9 8 IndexWidth (typedef in package MemTypes), 9 8 IndexWidth (typedef in package MMU), 13  A  a) vadd (function in package Arith), 8 a) vmul (function in package Arith), 7 AddrBeat#(numeric type addrWidth) (struct in package AddressGenerator), 7 AddressGenerator (interface in package AddressGenerator), 7 | deq() (Pipe::PipeOut method), 14 DmaDbg (interface in package MemTypes), 12  E enq() (Pipe::PipeIn method), 14 eq (function in package Arith), 7  F first() (Pipe::PipeOut method), 14 FirstLastPipe (interface in package Pipe), 17 FunnelPipesPipelined (instance in package Pipe), 17 FunnelPipesPipelined (typeclass in package Pipe), 16 FunnelPipesPipelined.mkFunnelPipesPipelined (module in package Pipe), 16 FunnelPipesPipelined.mkFunnelPipesPipelinedRR (module in package Pipe), 16 FunnelPipesPipelined.mkUnFunnelPipesPipelined (module in package Pipe), 17 FunnelPipesPipelined.mkUnFunnelPipesPipelinedRR (module in package Pipe), 17 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AddressGenerator (package), 7<br>Arith (package), 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | G (module in package ripe), 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit# (function in package Arith), 8 Bit#(32) SGLId (typedef in package MemTypes), 9 Bit#(TLog#(MaxNumSGLists)) RegionsIdx (typedef in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | getInterrupt (function in package Portal), 18<br>getInterruptVector (function in package Portal), 18<br>getMemoryTraffic() (MemTypes::DmaDbg method), 12<br>getSlave (function in package Portal), 18                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| package MMU), 13 Bit#(TLog#(MaxNumSGLists)) SGListId (typedef in package MMU), 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HostInterface (package), 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| booland (function in package Arith), 7<br>boolor (function in package Arith), 7<br>BsimHost (interface in package HostInterface), 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | isFirst() (Pipe::RangePipeIfc method), 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | isLast() (Pipe::RangePipeIfc method), 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Connectable (instance in package MemTypes), 13<br>Connectable (instance in package Pipe), 15<br>ConnectalTop (interface in package Portal), 18<br>CtrlMux (package), 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | LEDS (interface in package Leds), 9 Leds (package), 9 leds() (in package Leds), 9 Leds Width (typedef in package Leds), 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | LedsWidth (typedef in package Leds), 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| DataBusWidth (typedef in package HostInterface), 8 dbg() (MemTypes::DmaDbg method), 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | M mapPipe (function in package Pipe), 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| mapPipeIn (function in package Pipe), 15                                                   | mkRangePipeOut (module in package Pipe), 17           |
|--------------------------------------------------------------------------------------------|-------------------------------------------------------|
| MemData#(numeric type dsz) (struct in package Mem-                                         | mkRepeat (module in package Pipe), 16                 |
| Types), 10                                                                                 | mkSizedForkVector (module in package Pipe), 16        |
| MemengineCmd (struct in package MemTypes), 11                                              | mkSlaveMux (module in package CtrlMux), 8             |
| MemPortal (interface in package Portal), 18                                                | mkUnfunnel (module in package Pipe), 16               |
| MemPortal (package), 9                                                                     | mkUnfunnelGB (module in package Pipe), 16             |
| MemReadClient (interface in package MemTypes), 11                                          | mkUnfunnelPipes (module in package Pipe), 17          |
| MemreadEngine (package), 9                                                                 | mkUnFunnelPipesPipelinedInternal (module in package   |
| MemreadEngineV (interface in package MemTypes), 12                                         | Pipe), 17                                             |
| MemreadEngineV#(dataWidth,cmdQDepth,1) Memread-                                            | MMU (interface in package MMU), 13                    |
| Engine#(numeric type dataWidth, numeric type                                               | MMU (package), 13                                     |
| cmdQDepth) (typedef in package MemTypes),                                                  | MMUAddrServer (interface in package MMU), 13          |
| 12                                                                                         | MMUAddrServer.Vector (interface in package MMU), 13   |
| MemReadServer (interface in package MemTypes), 11                                          | mul (function in package Arith), 7                    |
| MemreadServer (interface in package MemTypes), 12                                          | N.I.                                                  |
| MemRequest (struct in package MemTypes), 10                                                | N                                                     |
| MemTypes (package), 9                                                                      | notEmpty() (Pipe::PipeOut method), 14                 |
| MemWriteClient (interface in package MemTypes), 11                                         | notFull() (Pipe::PipeIn method), 14                   |
| MemwriteEngineV (interface in package MemTypes), 12                                        | NumberOfMasters (typedef in package HostInterface), 8 |
| MemwriteEngineV#(dataWidth,cmdQDepth,1)                                                    |                                                       |
| MemwriteEngine#(numeric type dataW-                                                        | P                                                     |
| idth, numeric type cmdQDepth) (typedef in                                                  | PcieHost (interface in package HostInterface), 8      |
| package MemTypes), 12                                                                      | PhysAddrWidth (typedef in package HostInterface), 8   |
| MemWriteServer (interface in package MemTypes), 11                                         | PhysMemMaster (interface in package MemTypes), 10     |
| MemwriteServer (interface in package MemTypes), 12                                         | PhysMemReadClient (interface in package MemTypes),    |
| messageSize() (Portal::PipePortal method), 18                                              | 10                                                    |
| mkAddressGenerator (module in package AddressGener-                                        | PhysMemReadServer (interface in package MemTypes),    |
| ator), 7                                                                                   | 11                                                    |
| mkFirstLastPipe (module in package Pipe), 17                                               | PhysMemRequest#(numeric type addrWidth) (struct in    |
| mkForkVector (module in package Pipe), 16                                                  | package MemTypes), 9                                  |
| mkFunnel (module in package Pipe), 16                                                      | PhysMemSlave (interface in package MemTypes), 10      |
| mkFunnel1 (module in package Pipe), 16                                                     | PhysMemWriteClient (interface in package MemTypes),   |
| mkFunnelGB1 (module in package Pipe), 16                                                   | 10                                                    |
| mkFunnelPipes (module in package Pipe), 17                                                 | PhysMemWriteServer (interface in package MemTypes),   |
| mkFunnelPipes1 (module in package Pipe), 17                                                | 11                                                    |
| mkInterruptMux (module in package CtrlMux), 8                                              | Pipe (package), 14                                    |
| mkJoin (module in package Pipe), 16                                                        | PipeIn (interface in package Pipe), 14                |
| mkJoinBuffered (module in package Pipe), 16                                                | PipeOut (interface in package Pipe), 14               |
| mkJoinVector (module in package Pipe), 16                                                  | PipePortal (interface in package Portal), 18          |
| mkMapPipe (module in package Pipe), 15                                                     | Portal (package), 18                                  |
| mkMemPortal (module in package MemPortal), 9                                               | D                                                     |
| mkMemreadEngine(MemreadEngineV (module in package MemreadEngine), 9                        | R                                                     |
| mkMemreadEngineBuff (module in package Memread-                                            | RangeConfig#(type a) (struct in package Pipe), 17     |
| Engine), 9                                                                                 | RangePipeIfc (interface in package Pipe), 17          |
| mkMMU (module in package MMU), 13                                                          | ReqTup (struct in package MMU), 13                    |
| mkMMUAddrServer (module in package MMU), 14                                                | rshift (function in package Arith), 8                 |
| MkPipeIn (instance in package Pipe), 15                                                    |                                                       |
|                                                                                            | S                                                     |
| MkPipeIn (typeclass in package Pipe), 14<br>MkPipeIn.mkPipeIn (module in package Pipe), 14 | SharedMemoryPortal (interface in package Portal), 18  |
| mkPipelinedForkVector (module in package Pipe), 17                                         | start() (Pipe::FirstLastPipe method), 17              |
| MkPipeOut (instance in package Pipe), 15                                                   | start() (Pipe::RangePipeIfc method), 17               |
| MkPipeOut (typeclass in package Pipe), 13  MkPipeOut (typeclass in package Pipe), 14       | StdConnectalDmaTop (typedef in package Portal), 19    |
| MkPipeOut.mkPipeOut (module in package Pipe), 14                                           | StdConnectalTop (typedef in package Portal), 19       |
| ip acciding ip accidentally in package i ip -/, i -                                        | _ · · · _ · · · · · · · · · · · · · · ·               |

28 Index

### Т

```
toCountedPipeOut (function in package Pipe), 15
ToGet (instance in package Pipe), 15
ToPipeIn (instance in package Pipe), 14, 15
ToPipeIn (typeclass in package Pipe), 14
ToPipeIn.toPipeIn (function in package Pipe), 14
ToPipeOut (instance in package Pipe), 14, 15
ToPipeOut (typeclass in package Pipe), 14
ToPipeOut.toPipeOut (function in package Pipe), 14
ToPut (instance in package Pipe), 15
```

#### U

unvectorPipeOut (function in package Pipe), 15

#### V

```
Vector#(j,PipeOut#(a)) FunnelPipe#(numeric type j, numeric type k, type a, numeric type bitsPerCycle) (typedef in package Pipe), 16

Vector#(k,PipeOut#(a)) UnFunnelPipe#(numeric type j, numeric type k, type a, numeric type bitsPerCycle) (typedef in package Pipe), 16
```

## Ζ

zipPipeOut (function in package Pipe), 15 ZynqHost (interface in package HostInterface), 8

Index 29