Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Page Content

Table of Contents
minLevel1
maxLevel3
include
outlinefalse
indent
excludePage Content
typelist
class
printablefalse

Library

rtlab/Communication/SharedMemory

Block

The OpSharedMemoryCtrl block allows a user to open a shared memory in memory or on a physical

...

address.

...

OpSharedMemoryCtrl block

Mask

...

OpSharedMemoryCtrl mask.

Description

The OpSharedMemoryCtrl is used in a Master or Slave subsystem to open shared memory between physical memory or processes; the OpSharedMemoryRead and OpSharedMemoryWrite blocks allow users to communicate with the shared memory.

Parameters

Several parameters will become available depending on the shared memory type or the medium type parameters.

Controller ID

Specifies the controller ID that will be associated with each read and write blocks.

Shared memory base address

Specifies the memory base address of a physical card (ISA, PCI or Internal onboard device). The shared memory-type parameter must be set to Physical to activate this option. The address must be in hexadecimal format (Ex: 0xd4000).

Shared memory range

Specifies the memory range (size) that will be used to allocate memory on the computer. The range must be in hexadecimal format (Ex: 0x1000). This range is limited to the value 0x400000 for

linux

Linux operating system.

Shared memory offset

Number of address locations added to the base address to get the actual starting memory address control by the block. The offset must be in hexadecimal format (Ex: 0x100).

Shared memory type

When using a physical device such as a physical card (ISA, PCI, or Internal onboard device ) select the Physical option. This option is currently used for dual port memory device and can also be used to communicate with any card. When communicating with other processes on the computer, choose the Custom option. This option allows the user to communicate between different processes that use shared memory. When using the Custom option, specify a Shared memory object name to refer to the Shared Memory. If the object is not yet created, set the Create Object option.

Create object

This option allows the user to specify whether this controller will be the first to create the object, or only use it. This option should not be selected, for example, if you would like to communicate with another process that has already created its shared memory. This option is not available when using physical devices.

Shared memory object name

Specifies the name of the Shared memory object to be created, or the name of the object with which to communicate (Ex: test). This option is not available if you are using physical devices.

Memory byte ordering

Specifies whether the compatibility with the physical device will be little-endian or Big-endian. The x86 architecture is little-endian.

For example, the hexadecimal number 0x12345678 is stored in memory using little-endian as:

Image Removed
Image Added

Medium type

Selects ISA, PCI, or Internal device. When using the PCI option, specify the Vendor ID, Device ID, index of the PCI card, and the base address register with which to communicate. The Internal option allows the user to communicate with on board devices. This option is not available if you have selected the Custom option.

PCI Vendor ID

Specifies the vendor ID of the PCI Card used to hold the Shared Memory (Ex: 0x8086). On OPAL-RTLinux operating system, use the command 'lspci -n' to identify the vendor id.

PCI Device ID

Specifies the device ID of the PCI Card used to hold the Shared Memory (Ex: 0x7146). On OPAL-RTLinux operating system, use the command 'lspci -n' to identify the device id.

PCI Index

Specifies the PCI index of the card used to hold the Shared Memory (EX: 0).

PCI Base Address Register

Specifies the index of the PCI base address register to be used (EX: 0). This register holds the physical address of the corresponding Card's I/O Memory.

...

Note: PCI options are only valid when using a PCI medium type

Inputs

This block has no inputs.

Outputs

This block has no outputs.

Characteristics and Limitations

If this block is used with one VMIC 5565 card, the DMA transfer is used except if the environment variable ‘SHARE_MEM_NO_DMA’ is set.Image Modified

Direct Feedthrough

N/A

Discrete sample time

Yes

XHP support

Yes

Work offline

No