# **PCIe-Mini-Synchro**

## 16-BIT TRACKING RESOLVER-TO-DIGITAL CONVERTER

## **PCIexpress Mini**

928-10-000-4000

**Software MANUAL** 

Revision 1.0 September 2020

ALPHI TECHNOLOGY CORPORATION

1898 E. Southern Ave Tempe, AZ 85282 USA Tel: (480) 838-2428 Fax: (480) 838-4477

ALPHI TECHNOLOGY CORP.

Page i

**REV 1.0** 

### **NOTICE**

The information in this document has been carefully checked and is believed to be entirely reliable. While all reasonable efforts to ensure accuracy have been taken in the preparation of this manual, ALPHI TECHNOLOGY assumes no responsibility resulting from omissions or errors in this manual, or from the use of information contained herein.

ALPHI TECHNOLOGY reserves the right to make any changes, without notice, to this or any of ALPHI TECHNOLOGY's products to improve reliability, performance, function or design.

ALPHI TECHNOLOGY does not assume any liability arising out of the application or use of any product or circuit described herein; nor does ALPHI TECHNOLOGY convey any license under its patent rights or the rights of others.

### ALPHI TECHNOLOGY CORPORATION All Rights Reserved

This document shall not be duplicated, nor its contents used for any purpose, unless express permission has been granted in advance.

ALPHI TECHNOLOGY CORP.

Page ii

**REV 1.0** 

## **Table of Contents**

| Hierarchical Index  | 2  |
|---------------------|----|
| Class Index         | 3  |
| Class Documentation | 4  |
| AlphiBoard          |    |
| AlteraPio           |    |
| AlteraSpi           | 13 |
| BoardVersion        | 16 |
| ControlRegister     | 18 |
| Linear Address      | 21 |
| Ltc2754_av          | 22 |
| Ltc2754 SPI         | 25 |
| MINIPCIE_DEV_CTX    | 28 |
| PcieCra             | 29 |
| PCIeMini_Synch      | 31 |
| Rd19231             |    |
| StatusRegister      | 38 |
| Index               | 41 |
|                     |    |

## **Hierarchical Index**

## **Class Hierarchy**

| his inheritance list is sorted roughly, but not completely, alph |   |
|------------------------------------------------------------------|---|
| AlphiBoard                                                       |   |
| PCIeMini_Synch                                                   | 3 |
| AlteraPio                                                        | 1 |
| ControlRegister                                                  | 1 |
| StatusRegister                                                   | 3 |
| AlteraSpi                                                        | 1 |
| Ltc2664_SPI                                                      | 2 |
| BoardVersion                                                     | 1 |
| Linear Address                                                   | 2 |
| Ltc2664_av                                                       | 2 |
| MINIPCIE_DEV_CTX                                                 | 2 |
| PcieCra                                                          |   |
| Rd19231                                                          | 3 |

## **Class Index**

### **Class List**

| Here are the classes, structs, unions and interfaces with brief descriptions: |    |
|-------------------------------------------------------------------------------|----|
| AlphiBoard (Base class implementing a PCIe board and the Jungo driver )       | ∠  |
| AlteraPio (Altera Avalon Pio controller class )                               | 11 |
| AlteraSpi (Low level SPI interface to the SPI hardware )                      | 13 |
| BoardVersion (Board Hardware identification and version )                     | 16 |
| ControlRegister (Status register class for the PCIeMini board )               | 18 |
| LinearAddress (Memory Segment Descriptor )                                    | 21 |
| Ltc2664_av (Synchro simulator )                                               |    |
| Ltc2664_SPI (D/A controller SPI class definition )                            |    |
| MINIPCIE_DEV_CTX (Minipcie Device Information Structure )                     |    |
| PcieCra (PCIe controller class )                                              | 29 |
| PCIeMini_Synch (PCIeMini_Synchro controller board object )                    | 31 |
| Rd19231 (DDC RD19231 controller class )                                       |    |
| StatusRegister (Status register class for the PCIeMini hoard )                | 38 |

### **Class Documentation**

### **AlphiBoard Class Reference**

Base class implementing a PCIe board and the Jungo driver. #include <AlphiBoard.h>

Inheritance diagram for AlphiBoard:



### **Public Member Functions**

- AlphiBoard (UINT16 vendorId, UINT16 deviceId)
- ~AlphiBoard (void)

Destructor.

HRESULT Open (int brdNbr)

Open a board.

DWORD reset ()

reset some of the board resources

• uint32\_t getFpgaID ()

Get the FPGA ID of.

• time\_t getFpgaTimeStamp ()

Return the timestamp corresponding to when the FPGA was compiled.

void setVerbose (int verbose)

set the verbose flag

• bool **IsValidDevice** (const CHAR \*sFunc)

Validate a WDC device handle.

DWORD hookInterruptServiceRoutine (uint32\_t mask, MINIPCIE\_INT\_HANDLER uicr,

void \*userData)

Setup the interrupt of the board.

• DWORD hookInterruptServiceRoutine (MINIPCIE\_INT\_HANDLER uicr)

Set an interrupt handling routine.

 $\bullet \quad \text{DWORD } \textbf{unhookInterruptServiceRoutine} \ ()$ 

Disable the board interrupt.

• DWORD enableInterrupts (uint16\_t mask=0xffff)

ALPHI TECHNOLOGY CORP. Page 4 REV 1.0
Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

Enable PCIe interrupts.

### • DWORD disableInterrupts ()

Disable PCIe interrupts.

#### • DWORD Close ()

Close a device handle.

### volatile void \* getBar0Address (size\_t offset)

Return a pointer to an object in BAR 0.

### • volatile void \* **getBar2Address** (size\_t offset)

Return a pointer to an object in BAR 2.

### **Static Public Member Functions**

• static void **MsSleep** (int ms)

Millisecond Delay Function.

### **Public Attributes**

### LinearAddress bar0

Memory descriptor for the BAR0 in user memory.

#### • LinearAddress bar2

Memory descriptor for the BAR2 in user memory.

### • PcieCra \* cra

PCIe Interface instance.

### • BoardVersion \* sysid

Board identification.

### • int verbose

Flag used by various functions to determine the amount of messages to generate.

#### • DWORD libStatus

Status returned when trying to open the Jungo library. If it is not WD\_STATUS\_SUCCESS, the initialization failed.

ALPHI TECHNOLOGY CORP.

### **Detailed Description**

Base class implementing a PCIe board and the Jungo driver.

### **Constructor & Destructor Documentation**

AlphiBoard::AlphiBoard (UINT16 vendorld, UINT16 deviceld)

AlphiBoard::~AlphiBoard (void )

Destructor.

Will close the connection to the board if needed.

### **Member Function Documentation**

DWORD AlphiBoard::Close ()

Close a device handle.

### Returns

status, a Jungo status code

### DWORD AlphiBoard::disableInterrupts ()

Disable PCIe interrupts.

Disable the generation of PCIe interrupts by the PCIe interface, and the reception by the Windows driver.

#### **Return values**

|  | Status | code |  |
|--|--------|------|--|

### DWORD AlphiBoard::enableInterrupts (uint16\_t mask = 0xfffff)

Enable PCIe interrupts.

Enable the generation of PCIe interrupts by the board's PCIe interface. Enable the reception of PCIe interrupts by the Windows driver.

#### **Parameters**

| mask | Optional bit map of which local interrupt line is enabled (board dependent.) If |
|------|---------------------------------------------------------------------------------|
|      | not used, default to 0xffff - all local interrupts allowed.                     |

### **Return values**

| Status | code |
|--------|------|
|        |      |

ALPHI TECHNOLOGY CORP. Page 6 Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### volatile void \* AlphiBoard::getBar0Address (size\_t offset)

Return a pointer to an object in BAR 0.

#### **Parameters**

|   | offset        | Offset in BAR0 |  |  |  |
|---|---------------|----------------|--|--|--|
| R | Return values |                |  |  |  |
|   | Pointer       | to the object  |  |  |  |

### volatile void \* AlphiBoard::getBar2Address (size\_t offset)

Return a pointer to an object in BAR 2.

### **Parameters**

|               | offset  | Offset in BAR2 |
|---------------|---------|----------------|
| Return values |         |                |
|               | Pointer | to the object  |

### uint32\_t AlphiBoard::getFpgalD ()

Get the FPGA ID of.

#### **Returns**

The FPGA ID.

### time\_t AlphiBoard::getFpgaTimeStamp ()

Return the timestamp corresponding to when the FPGA was compiled.

### **Returns**

a timestamp.

### DWORD AlphiBoard::hookInterruptServiceRoutine (MINIPCIE\_INT\_HANDLER uicr)

Set an interrupt handling routine.

### **Parameters**

| uicr | user callback routine typedef void (stdcall    |
|------|------------------------------------------------|
|      | *UsersIntCompletionRoutine)(void *, uint32_t); |

### **Returns**

ERRCODE\_NO\_ERROR if successful.

### DWORD AlphiBoard::hookInterruptServiceRoutine (uint32\_t mask, MINIPCIE\_INT\_HANDLER uicr, void \* userData)

Setup the interrupt of the board.

Specify and interrupt service routine and enable the interrupts.

#### **Parameters**

| mask | board dependent interrupt mask.           |
|------|-------------------------------------------|
| uicr | pointer to the interrupt service routine. |

#### Returns

WD\_STATUS\_SUCCESS when the operation succeeded WD\_INVALID\_PARAMETER if the board is not opened WD\_OPERATION\_FAILED if the board does not have an interrupt resource WD\_OPERATION\_ALREADY\_DONE if there is already an isr active for the interrupt.

### bool AlphiBoard::IsValidDevice (const CHAR \* sFunc)

Validate a WDC device handle.

#### **Parameters**

| sFunc         | C-string with name of the function e.g. "IntEnable" |  |
|---------------|-----------------------------------------------------|--|
| Return values |                                                     |  |
| true          | if the device context exists.                       |  |

### static void AlphiBoard::MsSleep (int ms)[inline], [static]

Millisecond Delay Function.

### HRESULT AlphiBoard::Open (int brdNbr)

Open a board.

Establishes a connection to a board.

### **Parameters**

| *********** |                          |  |
|-------------|--------------------------|--|
| brdNbr      | the board index to open. |  |

### Returns

WD\_DEVICE\_NOT\_FOUND if there is no board corresponding to the number

### DWORD AlphiBoard::reset ()[inline]

reset some of the board resources

#### void AlphiBoard::setVerbose (int vb)

set the verbose flag

The verbose value is used to send more information to the log file or console. It is only partially implemented.

#### **Parameters**

| vb | Verbosity level. |
|----|------------------|

### DWORD AlphiBoard::unhookInterruptServiceRoutine ()

Disable the board interrupt.

#### **Parameters**

| mask | board dependent interrupt mask.           |
|------|-------------------------------------------|
| uicr | pointer to the interrupt service routine. |

#### Returns

WD\_STATUS\_SUCCESS when the operation succeeded WD\_INVALID\_PARAMETER if the board is not opened WD\_OPERATION\_FAILED if the board does not have an interrupt resource WD\_OPERATION\_ALREADY\_DONE if there the interrupt is already disabled.

#### **Member Data Documentation**

### LinearAddress AlphiBoard::bar0

Memory descriptor for the BAR0 in user memory.

### LinearAddress AlphiBoard::bar2

Memory descriptor for the BAR2 in user memory.

### PcieCra\* AlphiBoard::cra

PCIe Interface instance.

### DWORD AlphiBoard::libStatus

Status returned when trying to open the Jungo library. If it is not WD\_STATUS\_SUCCESS, the initialization failed.

### BoardVersion\* AlphiBoard::sysid

Board identification.

### int AlphiBoard::verbose

Flag used by various functions to determine the amount of messages to generate.

ALPHI TECHNOLOGY CORP. Page 9 REV 1.0
Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

The documentation for this class was generated from the following files:

- AlphiBoard.h
- AlphiBoard.cpp
- AlphiBoard\_irq.cpp

### **AlteraPio Class Reference**

Altera Avalon Pio controller class. #include <AlteraPio.h> Inheritance diagram for AlteraPio:

> AlteraPio ControlRegister StatusRegister

### **Public Member Functions**

- AlteraPio (volatile void \*addr, uint16\_t capabilities)
- PCIeMini status reset () Reset the PIO.
- uint32\_t getData ()
- PCIeMini\_status setData (uint32\_t data)
- uint32\_t getIrqMask ()
- PCIeMini\_status setIrqMask (uint32\_t mask)
- uint32 t getEdgeCapture ()
- PCIeMini\_status clearEdgeCapture (uint32\_t mask)

### **Static Public Attributes**

- static const uint16\_t **CAP\_INPUT** = 0x01
- static const uint16\_t CAP\_OUTPUT = 0x02
- static const uint16\_t **CAP\_INPUT\_OUTPUT** = 0x03

### **Detailed Description**

Altera Avalon Pio controller class.

### **Constructor & Destructor Documentation**

AlteraPio::AlteraPio (volatile void \* addr, uint16\_t capabilities)[inline]

Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### **Member Function Documentation**

PCleMini status AlteraPio::clearEdgeCapture (uint32 t mask)[inline]

uint32\_t AlteraPio::getData ()[inline]

uint32\_t AlteraPio::getEdgeCapture ()[inline]

uint32\_t AlteraPio::getIrqMask ()[inline]

PCleMini status AlteraPio::reset ()[inline]

Reset the PIO.

Whenever supported, set the direction register to all input, the data register to 0, and disable interrupts.

#### Return values

| Always | success |
|--------|---------|
|--------|---------|

PCleMini\_status AlteraPio::setData (uint32\_t data)[inline]

PCleMini\_status AlteraPio::setIrqMask (uint32\_t mask)[inline]

#### **Member Data Documentation**

const uint16\_t AlteraPio::CAP\_INPUT = 0x01[static]

const uint16\_t AlteraPio::CAP\_INPUT\_OUTPUT = 0x03[static]

const uint16\_t AlteraPio::CAP\_OUTPUT = 0x02[static]

The documentation for this class was generated from the following file:

AlteraPio.h

Page 12 Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### AlteraSpi Class Reference

Low level SPI interface to the SPI hardware. #include <AlteraSpi.h>

Inheritance diagram for AlteraSpi:



### **Public Member Functions**

- AlteraSpi (volatile void \*addr) Constructor.
- int **sendSpiCommand** (uint32\_t slave, uint32\_t write\_length, const uint8\_t \*write\_data, uint32\_t read\_length, uint8\_t \*read\_data, uint32\_t flags) Send an SPI command.
- uint32\_t **getRxData** () Get the content of the receive data register.
- uint32\_t **getStatus** ()
- void **setTxData** (uint32\_t data)
- void setControl (uint32\_t data)
- void selectSlave (uint32\_t data)

### **Static Public Attributes**

- static const uint32\_t status\_ROE\_mask = 0x0008 Receive - overrun error.
- static const uint32\_t **status\_TOE\_mask** = 0x0010 Transmitter-overrun error.
- static const uint32\_t **status\_TMT\_mask** = 0x0020 Transmitter shift-register empty.
- static const uint32\_t **status\_TRDY\_mask** = 0x0040 Transmitter ready.
- static const uint32\_t status\_RRDY\_mask = 0x0080 Receiver ready.

### **Detailed Description**

Low level SPI interface to the SPI hardware.

Page 13 Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

#### **Constructor & Destructor Documentation**

AlteraSpi::AlteraSpi (volatile void \* addr)

Constructor.

Called only when the board is opened.

#### **Parameters**

| [ | addn | Pointer to the device in year space  |
|---|------|--------------------------------------|
|   | addr | Pointer to the device in user space. |

#### **Member Function Documentation**

### uint32\_t AlteraSpi::getRxData()[inline]

Get the content of the receive data register.

#### **Return values**

| Content   | of the receive data register |
|-----------|------------------------------|
| Controlli | of the feet, e data register |

uint32\_t AlteraSpi::getStatus ()[inline]

void AlteraSpi::selectSlave (uint32\_t data)[inline]

int AlteraSpi::sendSpiCommand (uint32\_t slave, uint32\_t write\_length, const uint8\_t \* write\_data, uint32\_t read\_length, uint8\_t \* read\_data, uint32\_t flags)

Send an SPI command.

This is a very simple routine which performs one SPI master transaction. It would be possible to implement a more efficient version using interrupts and sleeping threads but this is probably not worthwhile initially.

#### **Parameters**

| slave        | Slave number select 0-31                                 |
|--------------|----------------------------------------------------------|
| write_length | Number of bytes to send                                  |
| write_data   | A pointer to the buffer containing the data to write     |
| read_length  | Number of bytes to receive                               |
| read_data    | A pointer to the buffer where the received data is going |
| flags        | A bit mask, only ALT_AVALON_SPI_COMMAND_TOGGLE_SS_N is   |
|              | used.                                                    |

#### Return values

| Number | of bytes read - in SPI read and write are simultaneous so it cannot be 0. |
|--------|---------------------------------------------------------------------------|

void AlteraSpi::setControl (uint32\_t data)[inline]

void AlteraSpi::setTxData (uint32\_t data)[inline]

ALPHI TECHNOLOGY CORP. Page 14

#### **Member Data Documentation**

### const uint32\_t AlteraSpi::status\_ROE\_mask = 0x0008[static]

Receive - overrun error.

The ROE bit is set to 1 if new data is received while the rxdata register is full(that is, while the RRDY bit is 1). In this case, the new data overwrites the old. Writing to the status register clears the ROE bit to 0.

### const uint32\_t AlteraSpi::status\_RRDY\_mask = 0x0080[static]

Receiver ready.

The RRDY bit is set to 1 when the rxdata register is full.

### const uint32\_t AlteraSpi::status\_TMT\_mask = 0x0020[static]

Transmitter shift-register empty.

In master mode, the TMT bit is set to 0 when a transaction is in progress and set to 1 when the shift register is empty.

### const uint32\_t AlteraSpi::status\_TOE\_mask = 0x0010[static]

Transmitter-overrun error.

The TOE bit is set to 1 if new data is written to the txdata register while it is still full (that is, while the TRDY bit is 0). In this case, the new data is ignored. Writing to the status register clears the TOE bit to 0.

### const uint32\_t AlteraSpi::status\_TRDY\_mask = 0x0040[static]

Transmitter ready.

The TRDY bit is set to 1 when the txdata register is empty.

### The documentation for this class was generated from the following files:

- AlteraSpi.h
- AlteraSpi.cpp

### **BoardVersion Class Reference**

Board Hardware identification and version. #include <AlphiBoard.h>

#### **Public Member Functions**

- BoardVersion (volatile uint32\_t \*addr) constructor
- uint32\_t getVersion ()

Version, if there is one programmed on the board hardware. Typically 0.

• time\_t getTimeStamp ()

Date when the board firmware was compiled.

### **Detailed Description**

Board Hardware identification and version.

#### **Constructor & Destructor Documentation**

BoardVersion::BoardVersion (volatile uint32\_t \* addr)

constructor

This constructor reads the chip register to initialize the data. It is called by the open and should not be called by the user.

#### **Parameters**

| addr | Offset to the sysid controller in the BAR2 address space |
|------|----------------------------------------------------------|

### **Member Function Documentation**

time t BoardVersion::getTimeStamp ()

Date when the board firmware was compiled.

uint32\_t BoardVersion::getVersion ()

Version, if there is one programmed on the board hardware. Typically 0.

### The documentation for this class was generated from the following files:

- AlphiBoard.h
- AlphiBoard.cpp

ALPHI TECHNOLOGY CORP. Page 16 REV 1.0
Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### **ControlRegister Class Reference**

Status register class for the PCIeMini board. #include <MiniSynchStatusRegister.h>

Inheritance diagram for ControlRegister:



### **Public Types**

- enum **Resolution** { **RES\_10\_BIT** = 0, **RES\_12\_BIT** = 1, **RES\_14\_BIT** = 2, **RES\_16\_BIT** = 3 }
- enum **ShiftControl** { VEL1 = 4, VEL2 = 0 }

### **Public Member Functions**

- ControlRegister (volatile void \*addr) Constructor.
- PCIeMini\_status enableSpiDa (bool enabled) Select the type of output of the D/A.

### **Static Public Attributes**

- static const uint32 t CTRL BITn MASK = 0x01
- static const uint32\_t CTRL\_AQB\_mask = 0x010
- static const uint32\_t CTRL\_DSR\_mask = 0x020
- static const uint32\_t CTRL\_DA\_CLEAR\_mask = 0x040
- static const uint32\_t CTRL\_DaMode\_mask = 0x400
- static const uint32\_t CTRL\_LDAC\_mask = 0x800

### **Detailed Description**

Status register class for the PCIeMini board.

#### **Member Enumeration Documentation**

enum ControlRegister::Resolution

#### **Enumerator:**

| RES_10_BIT |  |
|------------|--|
| RES_12_BIT |  |
| RES_14_BIT |  |
| RES_16_BIT |  |

Page 18 Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### enum ControlRegister::ShiftControl

#### **Enumerator:**

| VEL1 |  |
|------|--|
| VEL2 |  |

### **Constructor & Destructor Documentation**

ControlRegister::ControlRegister (volatile void \* addr)[inline]

Constructor.

Only called when the board is opened.

#### **Parameters**

| addr | Pointer to the device in user's space. |
|------|----------------------------------------|
|      | <u>.</u>                               |

### **Member Function Documentation**

PCleMini\_status ControlRegister::enableSpiDa (bool enabled)[inline]

Select the type of output of the D/A.

#### **Parameters**

| enabled | True when the D/As are general purpose, False when they are a synchro |
|---------|-----------------------------------------------------------------------|
|         | simulator                                                             |

### **Return values**

| EDD GODE WO E |  |
|---------------|--|
| ERRCODE_NO_E  |  |
| RROR          |  |
| KKOK          |  |

### **Member Data Documentation**

const uint32\_t ControlRegister::CTRL\_BITn\_MASK = 0x01[static]

const uint32\_t ControlRegister::CTRL\_AQB\_mask = 0x010[static]

const uint32\_t ControlRegister::CTRL\_DA\_CLEAR\_mask = 0x040[static]

const uint32\_t ControlRegister::CTRL\_DaMode\_mask = 0x400[static]

const uint32\_t ControlRegister::CTRL\_DSR\_mask = 0x020[static]

const uint32\_t ControlRegister::CTRL\_LDAC\_mask = 0x800[static]

The documentation for this class was generated from the following file:

MiniSynchStatusRegister.h

ALPHI TECHNOLOGY CORP. Page 19 REV 1.0
Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### **LinearAddress Struct Reference**

Memory Segment Descriptor. #include <AlphiBoard.h>

### **Public Attributes**

- void \* Address Linear address.
- size\_t Length Length of the mapping.

### **Detailed Description**

Memory Segment Descriptor.

### **Member Data Documentation**

void\* LinearAddress::Address

Linear address.

size\_t LinearAddress::Length

Length of the mapping.

The documentation for this struct was generated from the following file:

AlphiBoard.h

Page 21 Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### Ltc2664 av Class Reference

Synchro simulator. #include <Ltc2664 av.h>

#### **Public Member Functions**

- Ltc2664\_av (volatile void \*addr) Constructor.
- void **setSimGain** (int chanNbr, int16\_t val) Set an individual gain register.
- int16\_t **getSimGain** (int chanNbr) Get an individual gain register value.
- void **setAngle** (double angle) configure the sine amplitudes for a given angle
- double angleToRadian (uint32\_t intVal) fixed point angle to double
- uint32\_t radianToAngle (double rad) radian angle to fixed point
- double getFrequency (void)
- void **setFrequency** (double freq)
- void **setAngularVelocity** (double rad)
- double **getAngularVelocity** (void)
- uint32\_t getAngularVelocityRaw (void)

### **Detailed Description**

Synchro simulator.

This class allows controlling the on board simulator. It consists of 4 DAs, generating sinewaves at the proper frequency and amplitude to simulate a synchro output.

### **Constructor & Destructor Documentation**

Ltc2664\_av::Ltc2664\_av (volatile void \* addr)

Constructor.

To be called only by the board open.

#### **Parameters**

Base address of the board registers in user space. addr

Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### **Member Function Documentation**

### double Ltc2664\_av::angleToRadian (uint32\_t angle)

fixed point angle to double

This function converts a 17-bit angle value as a radian value as double.

#### **Parameters**

| angle    |       | 17-bit fixed point angle. |
|----------|-------|---------------------------|
| Return v | alues |                           |
| Doubl    | e     | value equivalent          |

double Ltc2664\_av::getAngularVelocity (void )[inline]

uint32\_t Ltc2664\_av::getAngularVelocityRaw (void )[inline]

double Ltc2664\_av::getFrequency (void )

int16\_t Ltc2664\_av::getSimGain (int chanNbr)

Get an individual gain register value.

#### **Parameters**

|   | chanNbr      | Gain number register (0 to 2). If the number is invalid, the function returns 0. |  |
|---|--------------|----------------------------------------------------------------------------------|--|
| R | eturn values |                                                                                  |  |
|   | 16-bit       | signed integer value                                                             |  |

### uint32\_t Ltc2664\_av::radianToAngle (double rad)

radian angle to fixed point

This function converts a radian value as double as a 17-bit angle value.

#### **Parameters**

|   | rad          | A double between -PI and +PI. |
|---|--------------|-------------------------------|
| R | eturn values |                               |
|   | 17-bit       | fixed point angle             |

### void Ltc2664\_av::setAngle (double angle)

configure the sine amplitudes for a given angle

For the synchro resolver, the angle is expressed as the amplitude of 3 sine waves.

This function, if given an angle calculates the gains of the 3 DA channels and thus the amplitudes of the sine waves generated.

#### **Parameters**

| _ |       |                            |  |
|---|-------|----------------------------|--|
|   | angle | A double between 0 and PI. |  |

ALPHI TECHNOLOGY CORP. Page 23

void Ltc2664\_av::setAngularVelocity (double rad)[inline]

void Ltc2664\_av::setFrequency (double freq)

void Ltc2664\_av::setSimGain (int chanNbr, int16\_t val)

Set an individual gain register.

### **Parameters**

| chanNbr | Gain number register (0 to 2). If the number is invalid, the function does |
|---------|----------------------------------------------------------------------------|
|         | nothing.                                                                   |
| val     | 16-bit value to put in the gain register.                                  |

The documentation for this class was generated from the following files:

- Ltc2664\_av.h
- Ltc2664\_av.cpp

ALPHI TECHNOLOGY CORP. Page 24 Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### Ltc2664 SPI Class Reference

D/A controller SPI class definition. #include <Ltc2664 SPI.h> Inheritance diagram for Ltc2664 SPI:

> AlteraSpi Ltc2754\_SPI

### **Public Types**

enum ChannelNbr: uint8\_t { CHANNEL\_0 = 0, CHANNEL\_1 = 1, CHANNEL\_2 = 2, CHANNEL\_3 = 3, CHANNEL\_ALL = 15, CHANNEL\_NONE = 14 } Definition of channel number possible parameters.

### **Public Member Functions**

- Ltc2664\_SPI (volatile void \*addr, ControlRegister \*control) Constructor.
- bool isChannelValid (ChannelNbr c) Check that a channel is a valid selection.
- void reset () Reset the LTC2664 chip.
- PCIeMini\_status setCode (int16\_t code, ChannelNbr channel, ChannelNbr update=CHANNEL\_NONE, bool echo=false) Set an output value to one or several D/A channels.

### **Public Attributes**

- uint8\_t **buff\_out** [4] output buffer, could be checked for verification
- uint8\_t **buff\_in** [4] input buffer, could be checked for verification
- ControlRegister \* controlReg

### **Additional Inherited Members**

### **Detailed Description**

D/A controller SPI class definition.

We interface to the LTC2664 chip through a standard SPI interface defined in AlteraSpi.

### **Member Enumeration Documentation**

enum Ltc2664\_SPI::ChannelNbr : uint8\_t

Definition of channel number possible parameters.

The commands to the LTC2664 have typically as an option the channel number, or all the channels, or if we want to disable part of a command, no channel.

#### **Enumerator:**

| CHANNEL_0     | Channel #0, first channel.     |
|---------------|--------------------------------|
| CHANNEL_1     | Channel #1, second channel.    |
| CHANNEL_2     | Channel #2, third channel.     |
| CHANNEL_3     | Channel #3, fourth channel.    |
| CHANNEL_ALL   | All the channels are selected. |
| CHANNEL_NON E | No channel, option disabled.   |

### **Constructor & Destructor Documentation**

Ltc2664\_SPI::Ltc2664\_SPI (volatile void \* addr, ControlRegister \* control)[inline]

Constructor.

Only called by the board open function.

### **Parameters**

| addr    | Pointer to the SPI controller in user space |
|---------|---------------------------------------------|
| control | Pointer to the Control Register object      |

### **Member Function Documentation**

bool Ltc2664\_SPI::isChannelValid (ChannelNbr c)[inline]

Check that a channel is a valid selection.

### **Parameters**

|    | c            | Channel number to check  |
|----|--------------|--------------------------|
| Re | eturn values |                          |
|    | True         | if the channel is valid. |

ALPHI TECHNOLOGY CORP. Page 26 REV 1.0
Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### void Ltc2664\_SPI::reset ()[inline]

Reset the LTC2664 chip.

PCIeMini status Ltc2664 SPI::setCode (int16 t code, ChannelNbr channel, ChannelNbr update = CHANNEL NONE, bool echo = false)

Set an output value to one or several D/A channels.

#### **Parameters**

| code    | Value to convert to analog out.                                            |
|---------|----------------------------------------------------------------------------|
| channel | Channel number or all the channels.                                        |
| update  | Which output to update after updating the value. Default is                |
|         | CHANNEL_NONE.                                                              |
| echo    | Determine if we are sending a 32-bit command (echo is true) so that we can |
|         | get an echo. Default is false, a 24-bit command, and no echo.              |

#### Return values

| ERRCODE_NO_E | if successful, ERRCODE_INVALID_VALUE if the parameters are |
|--------------|------------------------------------------------------------|
| RROR         | incompatible.                                              |

### **Member Data Documentation**

uint8\_t Ltc2664\_SPI::buff\_in[4]

input buffer, could be checked for verification

uint8\_t Ltc2664\_SPI::buff\_out[4]

output buffer, could be checked for verification

ControlRegister\* Ltc2664\_SPI::controlReg

The documentation for this class was generated from the following files:

- Ltc2664\_SPI.h
- Ltc2664\_SPI.cpp

Page 27 Copyright ALPHI Technology Corporation, 2020 Part Number: 928-10-000-4000

### MINIPCIE\_DEV\_CTX Struct Reference

Minipcie Device Information Structure. #include <AlphiBoard.h>

### **Public Attributes**

- MINIPCIE\_INT\_HANDLER funcDiagIntHandler Interrupt handler routine.
- MINIPCIE\_EVENT\_HANDLER funcDiagEventHandler Event handler routine.

### **Detailed Description**

Minipcie Device Information Structure.

### **Member Data Documentation**

MINIPCIE\_EVENT\_HANDLER MINIPCIE\_DEV\_CTX::funcDiagEventHandler

Event handler routine.

MINIPCIE\_INT\_HANDLER MINIPCIE\_DEV\_CTX::funcDiagIntHandler

Interrupt handler routine.

The documentation for this struct was generated from the following file:

AlphiBoard.h

Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### PcieCra Class Reference

PCIe controller class. #include <AlphiBoard.h>

#### **Public Member Functions**

- **PcieCra** (volatile void \*cra\_addr)
- void **reset** ()

  Reset the CRA PCIe interface.
- uint32\_t getIrqStatus ()
  return the interrupt status of the local IRQ lines
- void **setIrqEnableMask** (uint32\_t mask) Enable/disable the interrupts.
- uint32\_t **getIrqEnableMask** () return the interrupt enable mask

### **Detailed Description**

PCIe controller class.

This is a very simplified interface that just allows to enable/disable the interrupt requests to the PCIe bus and check the status of the local interrupt request lines.

### **Constructor & Destructor Documentation**

PcieCra::PcieCra (volatile void \* cra\_addr)[inline]

@constructor

### **Member Function Documentation**

uint32\_t PcieCra::getIrqEnableMask()[inline]

return the interrupt enable mask

uint32\_t PcieCra::getlrqStatus()[inline]

return the interrupt status of the local IRQ lines

In order for the PCIe interface to request an interrupt on the PCIe bus, the bit needs to be set in this register, and the corresponding bit should be set in the interrupt mask register.

ALPHI TECHNOLOGY CORP. Page 29 REV 1.0
Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### void PcieCra::reset ()[inline]

Reset the CRA PCIe interface.

Disable interrupts.

### void PcieCra::setIrqEnableMask (uint32\_t mask)[inline]

Enable/disable the interrupts.

### **Parameters**

| mask | bit mask of enabled interrupts |
|------|--------------------------------|
|------|--------------------------------|

The documentation for this class was generated from the following file:

• AlphiBoard.h

ALPHI TECHNOLOGY CORP. Page 30 REV 1.0 Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### PCleMini\_Synch Class Reference

PCIeMini\_Synchro controller board object. #include <PCIeMini\_Synch.h>

Inheritance diagram for PCIeMini\_Synch:



### **Public Member Functions**

- PCIeMini\_Synch ()
- **PCIeMini\_status open** (int brdNbr) *Open: connect to an actual board.*
- PCIeMini\_status close ()

Close the connection to a board object and free the resources.

• PCIeMini\_status reset ()
Reset the board controllers.

- void **setLedPio** (uint32 t)
- uint32\_t **getLedPio** ()

### **Static Public Member Functions**

• static char \* **getErrorMsg** (**PCIeMini\_status** errorNbr)

Return a text description corresponding to an error code.

### **Public Attributes**

- volatile uint32\_t \* ledPio LED control.
- ControlRegister \* controlRegister Interface to the board control register.
- StatusRegister \* statusRegister
  Interface to the board status register.
- Ltc2664\_av \* da
  Interface to the DAs when used as synchro simulator.
- Rd19231 \* sync Interface to the RD19231 Synchro resolver.
- Ltc2664\_SPI \* spi\_da
   SPI controller used by the DAs as general purpose DAs.

ALPHI TECHNOLOGY CORP. Page 31 REV 1.0
Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### **Static Public Attributes**

- static const uint16\_t irq\_mask\_statusReg = 0x0001 Interrupt mask for the status register (used for BITn)
- static const uint16\_t **irq\_mask\_spiInterface** = 0x0004 Interrupt mask for the SPI controller.

### **Detailed Description**

PCIeMini\_Synchro controller board object.

### **Constructor & Destructor Documentation**

### PCIeMini\_Synch::PCIeMini\_Synch ()

The constructor does not take any parameter. The board is not actually usable until the open method connects it to real hardware.

### **Member Function Documentation**

### PCleMini\_status PCleMini\_Synch::close ()

Close the connection to a board object and free the resources.

#### **Returns**

ERRCODE\_NO\_ERROR if successful.

### char \* PCleMini\_Synch::getErrorMsg (PCleMini\_status errorNbr)[static]

Return a text description corresponding to an error code.

#### Returns

A pointer to a null terminated character string.

### uint32\_t PCleMini\_Synch::getLedPio ()

### PCleMini\_status PCleMini\_Synch::open (int brdNbr)

Open: connect to an actual board.

ALPHI TECHNOLOGY CORP. Page 32 Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

#### **Parameters**

| brdNbr | The board number is actually system dependent but if you have only one | 1 |
|--------|------------------------------------------------------------------------|---|
|        | board, it should be 0.                                                 | l |

#### **Returns**

ERRCODE\_NO\_ERROR if successful.

### PCleMini\_status PCleMini\_Synch::reset ()

Reset the board controllers.

#### **Returns**

ERRCODE\_NO\_ERROR if successful.

void PCleMini Synch::setLedPio (uint32 t val)

### **Member Data Documentation**

### ControlRegister\* PCleMini\_Synch::controlRegister

Interface to the board control register.

### Ltc2664\_av\* PCleMini\_Synch::da

Interface to the DAs when used as synchro simulator.

#### const uint16 t PCleMini Synch::irg mask spilnterface = 0x0004[static]

Interrupt mask for the SPI controller.

### const uint16\_t PCleMini\_Synch::irq\_mask\_statusReg = 0x0001 [static]

Interrupt mask for the status register (used for BITn)

### volatile uint32\_t\* PCleMini\_Synch::ledPio

LED control.

### Ltc2664\_SPI\* PCleMini\_Synch::spi\_da

SPI controller used by the DAs as general purpose DAs.

### StatusRegister\* PCleMini\_Synch::statusRegister

Interface to the board status register.

ALPHI TECHNOLOGY CORP. Page 33

### Rd19231\* PCleMini\_Synch::sync

Interface to the RD19231 Synchro resolver.

### The documentation for this class was generated from the following files:

- PCIeMini\_Synch.h
- PCIeMini\_Synch.cpp

Page 34 ALPHI TECHNOLOGY CORP. Part Number: 928-10-000-4000

### Rd19231 Class Reference

DDC RD19231 controller class. #include <Rd19231.h>

### **Public Member Functions**

- Rd19231 (volatile void \*rd\_addr, StatusRegister \*status, ControlRegister \*control) Constructor.
- uint32\_t getRawPos () Read the Synchro raw binary output.
- double getPos () Get angular position.
- uint32\_t getCycleTime () Maintenance only.
- uint32\_t getBusyTime () Maintenance only.
- bool isBITnValid () Check if output is valid or if BIT error.
- uint32\_t getEncoderCounter () Get the encoder counter.
- void reset () for compatibility only

### **Detailed Description**

DDC RD19231 controller class.

The board hardware reads regularly the position data output to make sure the read position function returns the freshest data possible.

### **Constructor & Destructor Documentation**

Rd19231::Rd19231 (volatile void \* rd\_addr, StatusRegister \* status, ControlRegister \* control)[inline]

Constructor.

only called by the board open function

Page 35 Copyright ALPHI Technology Corporation, 2020 Part Number: 928-10-000-4000

### **Member Function Documentation**

uint32\_t Rd19231::getBusyTime()[inline]

Maintenance only.

uint32\_t Rd19231::getCycleTime ()[inline]

Maintenance only.

### uint32\_t Rd19231::getEncoderCounter()[inline]

Get the encoder counter.

Counting the A and B output pulses. Refer to the Synchro manual

double Rd19231::getPos()[inline]

Get angular position.

#### **Return values**

|            | 1                                |
|------------|----------------------------------|
| Position   | in degree, from 0 to 360 degrees |
| POSITION   | in degree from O to sou degrees  |
| 1 05111011 | in degree, from 0 to 500 degrees |

### uint32\_t Rd19231::getRawPos()[inline]

Read the Synchro raw binary output.

See **getPos()** for the output translated in degree

#### **Return values**

| A | 16-bit binary number |
|---|----------------------|

### bool Rd19231::isBITnValid ()[inline]

Check if output is valid or if BIT error.

The BIT error is triggered if any of the following conditions exist: ~180 LSBs of positive error, ~180 LSBs of negative error, Loss of Signal(LOS), or Loss of Reference(LOR) is less than 500 mVp, or a false null occurs when the phase detect circuitry causes a BIT and corrects the error.Logic 0 for fault condition.

#### **Return values**

| True | if valid read. False if there is a BIT error |
|------|----------------------------------------------|
|      | 1                                            |

### void Rd19231::reset ()[inline]

for compatibility only

### The documentation for this class was generated from the following file:

• Rd19231.h

ALPHI TECHNOLOGY CORP. Page 36 REV 1.0 Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### **StatusRegister Class Reference**

Status register class for the PCIeMini board.
#include <MiniSynchStatusRegister.h>

Inheritance diagram for StatusRegister:



### **Public Member Functions**

- StatusRegister (volatile void \*addr)
- bool **isBITnValid** ()

  Check the synchro error flag (BIT)
- void enableBitValidIrq ()

  Enable the synchro error interrupt.
- void disableBitValidIrq ()
   Disable the synchro error interrupt.

#### **Static Public Attributes**

• static const uint32\_t **STATUS\_BIT\_VALID\_MASK** = 0x01

### **Detailed Description**

Status register class for the PCIeMini board.

### **Constructor & Destructor Documentation**

StatusRegister::StatusRegister (volatile void \* addr)[inline]

### **Member Function Documentation**

void StatusRegister::disableBitValidIrq ()[inline]

Disable the synchro error interrupt.

void StatusRegister::enableBitValidIrq ()[inline]

Enable the synchro error interrupt.

The interrupt is generated on the error signal becoming active (BITn going low)

ALPHI TECHNOLOGY CORP. Page 38 REV 1.0
Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

### bool StatusRegister::isBITnValid ()[inline]

Check the synchro error flag (BIT)

### **Return values**

| true | if the sysnchro output is not in error |
|------|----------------------------------------|

### **Member Data Documentation**

const uint32\_t StatusRegister::STATUS\_BIT\_VALID\_MASK = 0x01[static]

The documentation for this class was generated from the following file:

MiniSynchStatusRegister.h

ALPHI TECHNOLOGY CORP. Page 39 Part Number:

## Index

| ~AlphiBoard                       | bar2                   |
|-----------------------------------|------------------------|
| AlphiBoard, 6                     | AlphiBoard, 9          |
| Address                           | BoardVersion, 16       |
| LinearAddress, 21                 | BoardVersion, 16       |
| AlphiBoard, 4                     | getTimeStamp, 16       |
| ~AlphiBoard, 6                    | getVersion, 16         |
| AlphiBoard, 6                     | buff_in                |
| bar0, 9                           | Ltc2664_SPI, 27        |
| bar2, 9                           |                        |
|                                   | buff_out               |
| Close, 6                          | Ltc2664_SPI, 27        |
| cra, 9                            | CAP_INPUT              |
| disableInterrupts, 6              | AlteraPio, 12          |
| enableInterrupts, 6               | CAP_INPUT_OUTPUT       |
| getBar0Address, 7                 | AlteraPio, 12          |
| getBar2Address, 7                 | CAP_OUTPUT             |
| getFpgaID, 7                      | AlteraPio, 12          |
| getFpgaTimeStamp, 7               | CHANNEL_0              |
| hookInterruptServiceRoutine, 7, 8 | Ltc2664_SPI, 26        |
| IsValidDevice, 8                  | CHANNEL_1              |
| libStatus, 9                      | Ltc2664_SPI, 26        |
| MsSleep, 8                        | CHANNEL_2              |
| Open, 8                           | Ltc2664_SPI, 26        |
| reset, 8                          | CHANNEL_3              |
| setVerbose, 9                     | Ltc2664_SPI, 26        |
| sysid, 9                          | CHANNEL_ALL            |
| · ·                               |                        |
| unhookInterruptServiceRoutine, 9  | Ltc2664_SPI, 26        |
| verbose, 9                        | CHANNEL_NONE           |
| AlteraPio, 11                     | Ltc2664_SPI, 26        |
| AlteraPio, 11                     | ChannelNbr             |
| CAP_INPUT, 12                     | Ltc2664_SPI, 26        |
| CAP_INPUT_OUTPUT, 12              | clearEdgeCapture       |
| CAP_OUTPUT, 12                    | AlteraPio, 12          |
| clearEdgeCapture, 12              | close                  |
| getData, 12                       | PCIeMini_Synch, 32     |
| getEdgeCapture, 12                | Close                  |
| getIrqMask, 12                    | AlphiBoard, 6          |
| reset, 12                         | controlReg             |
| setData, 12                       | Ltc2664_SPI, 27        |
| setIrqMask, 12                    | controlRegister        |
| AlteraSpi, 13                     | PCIeMini_Synch, 33     |
| AlteraSpi, 14                     | ControlRegister, 18    |
| getRxData, 14                     | ControlRegister, 19    |
| getStatus, 14                     | CTRL_AQB_mask, 19      |
| selectSlave, 14                   | CTRL_BITn_MASK, 19     |
| sendSpiCommand, 14                |                        |
| *                                 | CTRL_DA_CLEAR_mask, 19 |
| setControl, 14                    | CTRL_DaMode_mask, 19   |
| setTxData, 14                     | CTRL_DSR_mask, 19      |
| status_ROE_mask, 15               | CTRL_LDAC_mask, 19     |
| status_RRDY_mask, 15              | enableSpiDa, 19        |
| status_TMT_mask, 15               | RES_10_BIT, 18         |
| status_TOE_mask, 15               | RES_12_BIT, 18         |
| status_TRDY_mask, 15              | RES_14_BIT, 18         |
| angleToRadian                     | RES_16_BIT, 18         |
| Ltc2664_av, 23                    | Resolution, 18         |
| bar0                              | ShiftControl, 19       |
| AlphiBoard, 9                     | VEL1, 19               |
| -                                 |                        |

ALPHI TECHNOLOGY CORP.

Page 41

REV 1.0

| VEL2, 19              | AlteraPio, 12               |
|-----------------------|-----------------------------|
| cra                   | getIrqStatus                |
| AlphiBoard, 9         | PcieCra, 29                 |
| CTRL_AQB_mask         | getLedPio                   |
| ControlRegister, 19   | PCIeMini_Synch, 32          |
| CTRL_BITn_MASK        | getPos                      |
| ControlRegister, 19   | Rd19231, 36                 |
| CTRL_DA_CLEAR_mask    | getRawPos                   |
| ControlRegister, 19   | Rd19231, 36                 |
| CTRL_DaMode_mask      | getRxData                   |
| ControlRegister, 19   | AlteraSpi, 14               |
| CTRL_DSR_mask         | getSimGain                  |
| ControlRegister, 19   | Ltc2664_av, 23              |
| CTRL_LDAC_mask        | getStatus                   |
| ControlRegister, 19   | AlteraSpi, 14               |
| da                    | getTimeStamp                |
| PCIeMini_Synch, 33    | BoardVersion, 16            |
| disableBitValidIrq    | getVersion                  |
| StatusRegister, 38    | BoardVersion, 16            |
| disableInterrupts     | hookInterruptServiceRoutine |
| AlphiBoard, 6         |                             |
| enableBitValidIrq     | AlphiBoard, 7, 8            |
| <u> </u>              | irq_mask_spiInterface       |
| StatusRegister, 38    | PCIeMini_Synch, 33          |
| enableInterrupts      | irq_mask_statusReg          |
| AlphiBoard, 6         | PCIeMini_Synch, 33          |
| enableSpiDa           | isBITnValid                 |
| ControlRegister, 19   | Rd19231, 36                 |
| funcDiagEventHandler  | StatusRegister, 39          |
| MINIPCIE_DEV_CTX, 28  | isChannelValid              |
| funcDiagIntHandler    | Ltc2664_SPI, 26             |
| MINIPCIE_DEV_CTX, 28  | IsValidDevice               |
| getAngularVelocity    | AlphiBoard, 8               |
| Ltc2664_av, 23        | ledPio                      |
| getAngularVelocityRaw | PCIeMini_Synch, 33          |
| Ltc2664_av, 23        | Length                      |
| getBar0Address        | LinearAddress, 21           |
| AlphiBoard, 7         | libStatus                   |
| getBar2Address        | AlphiBoard, 9               |
| AlphiBoard, 7         | LinearAddress, 21           |
| getBusyTime           | Address, 21                 |
| Rd19231, 36           | Length, 21                  |
| getCycleTime          | Ltc2664_av, 22              |
| Rd19231, 36           | angleToRadian, 23           |
| getData               | getAngularVelocity, 23      |
| AlteraPio, 12         | getAngularVelocityRaw, 23   |
| getEdgeCapture        | getFrequency, 23            |
| AlteraPio, 12         | getSimGain, 23              |
| getEncoderCounter     | Ltc2664_av, 22              |
| Rd19231, 36           | radianToAngle, 23           |
| getErrorMsg           | setAngle, 23                |
| PCIeMini_Synch, 32    | setAngularVelocity, 24      |
| getFpgaID             | setFrequency, 24            |
| AlphiBoard, 7         | setSimGain, 24              |
| getFpgaTimeStamp      | Ltc2664_SPI, 25             |
| AlphiBoard, 7         | buff_in, 27                 |
| getFrequency          | buff_out, 27                |
| Ltc2664_av, 23        | CHANNEL_0, 26               |
| getIrqEnableMask      | CHANNEL_1, 26               |
| PcieCra, 29           | CHANNEL_2, 26               |
|                       | — <del>-</del> /            |
| getIrqMask            | CHANNEL_3, 26               |

| CHANNEL_ALL, 26           | AlteraPio, 12             |
|---------------------------|---------------------------|
| CHANNEL_NONE, 26          | Ltc2664_SPI, 27           |
| ChannelNbr, 26            | PcieCra, 30               |
| controlReg, 27            | PCIeMini_Synch, 33        |
| isChannelValid, 26        | Rd19231, 36               |
| Ltc2664_SPI, 26           | Resolution                |
| reset, 27                 | ControlRegister, 18       |
| setCode, 27               | selectSlave               |
| MINIPCIE_DEV_CTX, 28      | AlteraSpi, 14             |
| funcDiagEventHandler, 28  | sendSpiCommand            |
| funcDiagIntHandler, 28    | AlteraSpi, 14             |
| MsSleep                   | setAngle                  |
| AlphiBoard, 8             | Ltc2664_av, 23            |
| open                      | setAngularVelocity        |
| PCIeMini_Synch, 32        | Ltc2664_av, 24            |
| Open                      | setCode                   |
| AlphiBoard, 8             | Ltc2664_SPI, 27           |
| PcieCra, 29               | setControl                |
| getIrqEnableMask, 29      | AlteraSpi, 14             |
|                           | setData                   |
| getIrqStatus, 29          | AlteraPio, 12             |
| PcieCra, 29               |                           |
| reset, 30                 | setFrequency              |
| setIrqEnableMask, 30      | Ltc2664_av, 24            |
| PCIeMini_Synch, 31        | setIrqEnableMask          |
| close, 32                 | PcieCra, 30               |
| controlRegister, 33       | setIrqMask                |
| da, 33                    | AlteraPio, 12             |
| getErrorMsg, 32           | setLedPio                 |
| getLedPio, 32             | PCIeMini_Synch, 33        |
| irq_mask_spiInterface, 33 | setSimGain                |
| irq_mask_statusReg, 33    | Ltc2664_av, 24            |
| ledPio, 33                | setTxData                 |
| open, 32                  | AlteraSpi, 14             |
| PCIeMini_Synch, 32        | setVerbose                |
| reset, 33                 | AlphiBoard, 9             |
| setLedPio, 33             | ShiftControl              |
| spi_da, 33                | ControlRegister, 19       |
| statusRegister, 33        | spi_da                    |
| sync, 34                  | PCIeMini_Synch, 33        |
| radianToAngle             | STATUS_BIT_VALID_MASK     |
| Ltc2664_av, 23            | StatusRegister, 39        |
| Rd19231, 35               | status_ROE_mask           |
| getBusyTime, 36           | AlteraSpi, 15             |
| getCycleTime, 36          | status_RRDY_mask          |
| getEncoderCounter, 36     | AlteraSpi, 15             |
| getPos, 36                | status_TMT_mask           |
| getRawPos, 36             | AlteraSpi, 15             |
| isBITnValid, 36           | status_TOE_mask           |
| Rd19231, 35               | AlteraSpi, 15             |
| reset, 36                 | status_TRDY_mask          |
| RES_10_BIT                | AlteraSpi, 15             |
| ControlRegister, 18       | statusRegister            |
| RES_12_BIT                | PCIeMini_Synch, 33        |
| ControlRegister, 18       | StatusRegister, 38        |
| RES_14_BIT                | disableBitValidIrq, 38    |
| ControlRegister, 18       | enableBitValidIrq, 38     |
| RES_16_BIT                | isBITnValid, 39           |
| ControlRegister, 18       | STATUS_BIT_VALID_MASK, 39 |
| reset                     | StatusRegister, 38        |
| AlphiBoard, 8             | sync                      |
| inpinibourd, o            | 5,110                     |

ALPHI TECHNOLOGY CORP. Page 43 REV 1.0
Part Number: 928-10-000-4000 Copyright ALPHI Technology Corporation, 2020

PCIeMini\_Synch, 34 sysidAlphiBoard, 9 unhook Interrupt Service RoutineAlphiBoard, 9 VEL1

ControlRegister, 19 ControlRegister, 19 verbose AlphiBoard, 9

Page 44 ALPHI TECHNOLOGY CORP.