Document toolboxDocument toolbox

(8.D.2.4) IPCBuffer

Overview

Buffer data between instances through shared heap

Discussion

IPCBuffer routes all input wire data to a user-defined instance ID. All of the downstream modules connected to the output pin will inherit the instance ID configured by the user. This module requires the configuration and initialization of the AWECore shared heap on all instances of a target. Designs including IPCBuffer will fail to build without the existence of shared heap.

IPCBuffer allows a user to select the instance ID to which all input pin data will route to using the parameter targetInstance. IPCBuffer does not modify the input data in any way, but instead handles the IPC layer routing through AWECore's shared heap, to provide an abstracted multi-instance design interface.

The module supports multiple input and output pins. The input wires must all be on the same clock divider, but they can all have different block sizes, sample rates, and data types.

The module optionally allows you to increase or decrease the clock divider by an integer factor (bufferUpDownFactor). This causes the output block size to increase or decrease by bufferUpDownFactor as well. That means, if bufferUpDownFactor > 0 the output clock divider and block size increased by bufferUpDownFactor and if bufferUpDownFactor < 0 then the output clock divider and block size decreased by bufferUpDownFactor. If bufferUpDownFactor == 0 then the output clock divider and block size inherited from the input pin Larger clock dividers end up going into lower priority layouts.

The module also optionally allows you to specify the output layoutSubID. The layoutSubID allows you to run multiple sets of modules at the same clockDivider but in different layouts. For example, you might have multiple layouts all at a clock divider of 1 operating in a SMP core system. When using Designer, layoutSubID is selected in a droplist to be 'A' to 'P' which corresponds to 16 unique layouts. When using Matlab scripts, layoutSubID is an integer in the range [0 15] which maps directly to [A P]. If layoutSubID is empty, then the thread ID is inherited from the input pin.

Layouts are specified using a combination of bufferUpDownFactor and layoutSubID. The system input pin is always in layout 1A. The system output pin can be on any of the clockDivider 1 layouts (1A, 1B, etc.). If you want multiple layouts all at the same block time as the input pin, then select 1B, 1C, and so forth.

This module introduces a sample latency equal to the bufferUpDownFactor times input pin's block size if bufferUpDownFactor > 0 and input pin's block size otherwise.

Note: This module is released as a beta feature, and may change in incompatible ways in future releases

Type Definition

-- Not Shown --

Pins

Input Pins

Name: in1

Description: audio input

Data type: {float, int, fract32}

Channel range: Unrestricted

Block size range: Unrestricted

Sample rate range: Unrestricted

Complex support: Real and Complex

Output Pins

Name: out1

Description: audio output

Data type: {float, int, fract32}

MATLAB Usage

File Name: ipc_buffer_subsystem.m

SYS = ipc_buffer_subsystem(NAME, NUMPINS, TARGETINSTANCE) Creates an IPC audio module which occupies shared memory, allowing for multi-instance audio buffer sharing to abstract IPC audio routing. NAME - name of the module. NUMPINS - number of pins on input and output TARGETINSTANCE - the output layout can run on a different coreID than the input layout. TARGETINSTANCE specifies which instanceID layout the IPCFifoOut buffer will be processed from. By default, TARGETINSTANCE=0. BUFFER_UP_DOWN_FACTOR - the output instance can run at a larger or smaller clock divider (block size) compared to the input instance. BUFFER_UP_DOWN_FACTOR is the multiplicative or divisor factor which connects the input and output: If BUFFER_UP_DOWN_FACTOR is > 0: outputBlockSize = inputBlockSize * BUFFER_UP_DOWN_FACTOR outputClockDivider = inputClockDivider * BUFFER_UP_DOWN_FACTOR If BUFFER_UP_DOWN_FACTOR < 0: outputBlockSize = inputBlockSize / abs(BUFFER_UP_DOWN_FACTOR) outputClockDivider = inputClockDivider / abs(BUFFER_UP_DOWN_FACTOR) By default, BUFFER_UP_DOWN_FACTOR=0 which inherits properties from input to output. LAYOUT_SUB_ID - allows you to specify which sublayout ID will be used to process the output clockDivider. By default, this is empty which indicates that the ID from input is inherited to output. The sublabel is an integer in the range [0 15] which provides finer control over which layout to join. By default, LAYOUT_SUB_ID=[], which causes inherit from input. Note: This module is released as a beta feature, and may change in incompatible ways in future releases

Â