# Single-Board RIO Device Reference and Procedures



# Contents

| Single-Board RIO                            | . 5 |
|---------------------------------------------|-----|
| sbRIO-9603/9608/9609/9628/9638/9629 CAN API | . 5 |
| sbRIO-9603/9608/9609/9628/9638/9629 CAN API | . 5 |
| CAN FPGA I/O Properties Dialog Box          | . 8 |
| CAN Input                                   | 12  |
| CAN Output                                  | 20  |
| Custom Baudrate Dialog Box                  | 28  |
| Custom FD Baudrate Dialog Box               | 29  |
| I/O Properties                              | 30  |
| Overview                                    | 30  |
| Baud Rate                                   | 31  |
| Baud Rate Advanced                          | 32  |
| FD Baud Rate                                | 33  |
| FD Baud Rate Advanced                       | 33  |
| Comm State                                  | 34  |
| Listen Only                                 | 35  |
| I/O Mode                                    | 35  |
| Input Timeout                               | 36  |
| Output Timeout (ms)                         | 36  |
| Log Bus Errors                              | 37  |
| Log Transceiver Faults                      | 38  |
| Self Reception                              | 39  |
| Single Shot Transmit                        | 39  |
| Receive Error Counter                       | 40  |
| Transmit Error Counter                      | 40  |
| Transceiver Mode                            | 40  |
| I/O Methods                                 | 41  |
| Reset                                       | 41  |
| Start                                       | 42  |
| Stop                                        | 42  |
| Abort Transmit                              | 43  |
| Wait on Comm State Change                   | 44  |
| Wait on Transceiver Wakeun                  | 45  |

| Wait on Transmit Complete                                                 | 46  |
|---------------------------------------------------------------------------|-----|
| sbRIO-9603                                                                | 47  |
| sbRIO-9607                                                                | 49  |
| sbRIO-9608                                                                | 50  |
| sbRIO-9609                                                                | 52  |
| sbRIO-9627                                                                | 53  |
| sbRIO-9627                                                                | 53  |
| sbRIO-9627 (FPGA Interface)                                               | 55  |
| sbRIO-9628                                                                | 57  |
| sbRIO-9628                                                                | 57  |
| sbRIO-9628 (FPGA Interface)                                               | 59  |
| Converting Analog Input Values for the sbRIO-9628/9638 (FPGA Interface)   | 64  |
| Converting Analog Output Values for the sbRIO-9628/9638 (FPGA Interface). | 65  |
| Module Properties Dialog Box for the sbRIO-9628/9638 (FPGA Interface)     | 66  |
| sbRIO-9629                                                                | 68  |
| sbRIO-9629                                                                |     |
| sbRIO-9629 (FPGA Interface)                                               |     |
| sbRIO-9637                                                                |     |
| sbRIO-9637                                                                |     |
| sbRIO-9637 (FPGA Interface)                                               |     |
| sbRIO-9638                                                                |     |
| sbRIO-9638                                                                |     |
| sbRIO-9638 (FPGA Interface)                                               |     |
|                                                                           | 87  |
|                                                                           | 89  |
| Module Properties Dialog Box for the sbRIO-9628/9638 (FPGA Interface)     | 90  |
| sbRIO-9651                                                                |     |
| sbRIO-9651                                                                |     |
| Getting Started with the sbRIO-9651 in LabVIEW                            | 97  |
|                                                                           | 97  |
|                                                                           | 98  |
| , ,                                                                       | 99  |
|                                                                           | .00 |
| Implementing FPGA VIs for the sbRIO-9651                                  | .01 |

| RI | O Mezzanine Cards                                                     | 103  |
|----|-----------------------------------------------------------------------|------|
|    | sbRIO-9683                                                            | 103  |
|    | sbRIO-9683                                                            | 103  |
|    | sbRIO-9683 (FPGA Interface)                                           | 104  |
|    | Avoiding Timing Uncertainty with the NI 9683 (FPGA Interface)         | 110  |
|    | RIO Mezzanine Card Properties Dialog Box for the NI 9683 (FPGA Interf | ace) |
|    |                                                                       | 110  |
|    | Scaling NI 9683 Analog Input Values (FPGA Interface)                  | 111  |
|    | Scaling NI 9683 Analog Output Values (FPGA Interface)                 | 112  |
|    | sbRIO-9684                                                            | 112  |
|    | sbRIO-9684                                                            | 112  |
|    | sbRIO-9684 (FPGA Interface)                                           | 114  |
|    | Avoiding Timing Uncertainty with the sbRIO-9684 (FPGA Interface)      | 120  |
|    | RIO Mezzanine Card Properties Dialog Box for the sbRIO-9684 (FPGA     |      |
|    | Interface)                                                            | 120  |
|    | Scaling sbRIO-9684 Analog Input Values (FPGA Interface)               | 121  |
|    | Scaling sbRIO-9684 Analog Output Values (FPGA Interface)              | 123  |
|    | sbRIO-9694                                                            | 123  |
|    | sbRIO-9694                                                            | 123  |
|    | sbRIO-9694 (FPGA Interface)                                           | 124  |
|    | sbRIO-9697                                                            | 126  |
|    | sbRIO-9697                                                            | 126  |
|    | sbRIO-9697 (FPGA Interface)                                           | 127  |
|    | sbRIO-9698                                                            | 129  |
|    | sbRIO-9698                                                            | 129  |
|    | sbRIO-9698 (FPGA Interface)                                           | 130  |
|    | NI Digital I/O Mezzanine Card                                         | 132  |
|    | NI Digital I/O Mezzanine Card                                         | 132  |
|    | NI Digital I/O Mezzanine Card (FPGA Interface)                        | 132  |

## Single-Board RIO Device Reference and Procedures

Use this book as a reference for information about using Single-Board RIO (sbRIO) devices with NI CompactRIO Device Drivers in LabVIEW.



To view related topics, click the **Locate** button, shown at left, in the toolbar at the top of this window. The **LabVIEW Help** highlights this topic in the **Contents** tab so you can navigate the related topics.

© 2014–2023 National Instruments Corporation. All rights reserved.

sbRIO-9603/9608/9609/9628/9638/9629 CAN API

FPGA I/O Node

You can use an FPGA I/O Node for either CAN Input or CAN Output.

Terminals in Software

You can select the following terminals for this device.

| Terminal | Description |
|----------|-------------|
| CAN0     | CAN Port 0  |

## I/O Methods

You can use the following I/O methods on the sbRIO-9603/9608/9609/9628/9638/9629.

| Method         | Description                                                               |
|----------------|---------------------------------------------------------------------------|
| Abort Transmit | Abort a pending CAN frame transmission.                                   |
| Reset          | Reset the CAN port to the same state as when the FPGA VI started running. |
| <u>Start</u>   | Start communication.                                                      |

| Stop                       | Stop communication.                                                                                                                       |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Comm State Change  | Wait for a change in the communication state of the CAN port (Comm State property).                                                       |
| Wait on Transceiver Wakeup | Wait for the Transceiver Mode property to chang<br>e from Sleep to Normal mode due to a remote w<br>akeup (bus activity) or local wakeup. |
| Wait on Transmit Complete  | Wait for <b>all</b> frames written to CAN Output to complete transmission.                                                                |

## I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following properties with the sbRIO-9603/9608/9609/9628/9638/9629.

| Property                  | Description                                                                                              | Read While<br>Stopped? | Read While Running? | Write While Stopped? | Write While Running? |
|---------------------------|----------------------------------------------------------------------------------------------------------|------------------------|---------------------|----------------------|----------------------|
| Baud Rate                 | Specifies the b<br>aud rate and d<br>efault sample p<br>oint for CAN bu<br>s.                            | No                     | No                  | Yes                  | No                   |
| Baud Rate Adv<br>anced    | Specifies custo<br>m baud rate an<br>d sample point<br>for CAN bus.                                      | No                     | No                  | Yes                  | No                   |
| FD Baud Rate              | Specifies the b<br>aud rate and d<br>efault sample p<br>oint for CAN bu<br>s with flexible<br>data rate. | No                     | No                  | Yes                  | No                   |
| FD Baud Rate A<br>dvanced | Specifies custo m baud rate an d sample point for CAN bus wit h flexible data r ate.                     | No                     | No                  | Yes                  | No                   |
| Comm State                | Describes the c urrent commu                                                                             | Yes                    | Yes                 | N/A                  | N/A                  |

|                            | nication state o<br>f the CAN contr<br>oller.                                                                                     |    |    |     |     |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|----|----|-----|-----|
| Listen Only                | Controls listen-<br>only mode for<br>passive monito<br>ring/logging.                                                              | No | No | Yes | No  |
| I <u>/O Mode</u>           | Sets the CAN o<br>perating mode<br>to CAN(default)<br>, CAN FD or CA<br>N FD + BRS.                                               | No | No | Yes | No  |
| Input Timeout (ms)         | Specifies the ti<br>me to wait for t<br>he reading of C<br>AN frame using<br>CAN Input. The<br>resolution is in<br>milliseconds.  | No | No | Yes | No  |
| Output Timeou<br>t (ms)    | Specifies the ti<br>me to wait for t<br>he writing of C<br>AN frame using<br>CAN Output. T<br>he resolution is<br>in milliseconds | No | No | Yes | No  |
| Log Bus Errors             | Enables the log<br>ging of bus err<br>ors as frames t<br>hat can be read<br>using the CAN I<br>nput node.                         | No | No | Yes | Yes |
| Log Transceive<br>r Faults | Enables the log<br>ging of transcei<br>ver faults as fra<br>mes that can b<br>e read using th<br>e CAN Input no<br>de.            | No | No | Yes | Yes |

| Self Reception            | Specifies whet<br>her to echo suc<br>cessfully trans<br>mitted CAN fra<br>mes to be read<br>using CAN Inpu<br>t.     | No  | No  | Yes | Yes |
|---------------------------|----------------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|
| Single Shot Tra<br>nsmit  | Specifies whet<br>her to retry fail<br>ed CAN frame t<br>ransmissions.                                               | No  | No  | Yes | No  |
| Receive Error C<br>ounter | Provides acces<br>s to the CAN co<br>ntroller Receiv<br>e Error Counter                                              | Yes | Yes | N/A | N/A |
| Transmit Error<br>Counter | Provides acces<br>s to the CAN co<br>ntroller Transm<br>it Error Counte<br>r.                                        | Yes | Yes | N/A | N/A |
| Transceiver Mo<br>de      | Sets the mode<br>for the CAN tra<br>nsceiver and th<br>e associated m<br>ode in the TCA<br>N4550 CAN con<br>troller. | No  | Yes | No  | Yes |

## CAN FPGA I/O Properties Dialog Box

The CAN FPGA I/O Properties dialog box includes the following properties that you can use to configure the CAN functionality. To open the dialog box, right-click **CANO** in the Project Explorer window and select **Properties**.

#### Baud Rate

This property specifies the Baud Rate for the transceiver when in classical CAN mode or when transmitting data before the BRS bit when in CAN FD + BRS mode. You must always set Baud Rate even when the I/O Mode is set to CAN FD + BRS

because the CAN FD + BRS protocol always has a portion of the frame that transfer in classical CAN mode.

Typical baud rates are listed as kilobits per second. The supported values are 5.00, 6.150, 10.00, 12.5, 16.00, 20.00, 25.00, 31.25, 33.33, 40.00, 50.00, 62.50, 80.00, 83.33, 100.0, 125.0, 160.0, 200.0, 250.0, 400.0, 500.0, 800.0, and 1000. These bit fields are selected to create the desired baud rate with a default sample point of 87.5%. The default baud rate is 500.0 kb/s.

If you prefer a custom sample point, select < Custom > and the Custom Baud Rate dialog box will appear that you can use to determine the values to put in this field to obtain the desired sample point.

#### FD Baud Rate

This property specifies the baud rate for the transceiver when in FD + BRS CAN mode while transmitting data after the BRS bit. You need to set the FD Baud Rate or FD Baud Rate Advanced properties only when the I/O Mode is set to CAN FD + BRS.

Typical FD baud rates are listed as kilobits per second. The supported values are 200, 250, 400, 500, 800, 1000, 1250, 1600, 2000, 2500, 4000, and 5000. These bit fields are selected to create the desired band rate with a default sample point of 87.5%. The default FD Baud Rate is 500.0 kb/s.

If you prefer a custom sample point, select < Custom > and the Custom FD Baud Rate dialog box will appear that you can use to determine the values to put in this field to obtain the desired sample point.

#### I/O Mode

This configures the CAN operating mode. The values are:

CAN(default) Default CAN 2.0

**CAN FD** CAN FD mode as specified in the CAN with

Flexible Data-Rate specification, version 1.0

CAN FD as specified in the CAN with Flexible CAN FD + BRS Data-Rate specification, version 1.0, with the

optional Baud Rate Switching enabled.

#### Input Timeout (ms)

The Input Timeout (ms) property specifies how long to wait for a new frame to be received. It is a signed 32-bit integer with a resolution of milliseconds, thus allowing a maximum value of approximately 25 days. Special values of 0 (do not wait) and -1 (wait indefinitely) are supported. The default input timeout is 10000 ms.

If you specify an Input Timeout (ms) of 0, the CAN Input node will simply check to see if a new frame has arrived (non-blocking). If a new frame exists, CAN Input returns the frame with an error status of FALSE (success). If no new frame exists, CAN Input returns an error status of TRUE (error). Therefore, you must enable Error Terminals for the CAN Input node in order to poll for new frames when using an input timeout of 0. When an error is returned, you must invoke the CAN Input node again at a later time to ensure no data is lost.

#### Output Timeout (ms)

The Output Timeout (ms) property specifies how long to wait for a new element to become available, which occurs when a frame from a previous CAN Output transmits successfully onto the network. If you specify an Output Timeout (ms) of 0, the CAN Output node returns an error status of TRUE (error) if a new element is not available in the FIFO (non-blocking). When an error is returned, you must attempt CAN Output of the same frame again at a later time. Special values of 0 (do not wait) and -1 (wait indefinitely) are supported. The default output timeout is 10000 ms.

#### **Auto Start**

This Boolean property indicates whether to invoke the Start method automatically when the FPGA VI runs. The default is TRUE (enabled).

When Auto Start is TRUE (enabled), the Start method is invoked automatically when the FPGA VI runs, and the Stop method is invoked automatically when the FPGA VI stops running. This enables your FPGA VI diagram to begin using CAN Input and CAN Output nodes without first using an explicit Start method.

When Auto Start is FALSE (disabled), the Start method is not invoked automatically. You must use the Start method in your FPGA VI diagram in order to start communication.

#### Log Bus Errors

This Boolean control indicates whether to enable the Log Bus Errors feature for logging of bus errors as frames that can be read using the CAN Input node. The default is FALSE(disabled).

When Log Bus Errors is TRUE (enabled), the bus errors will be logged as frames and can be read using the CAN Input node.

When Log Bus Errors is FALSE (disabled), the bus errors will not be logged and cannot be read using the CAN Input node (default).

#### Log Transceiver Faults

This Boolean control indicates whether to enable the Log Transceiver Faults feature for logging of transceiver faults as frames that can be read using the CAN Input node. The default is FALSE(disabled).

When Log Transceiver Faults is TRUE (enabled), the logging is enabled and the transceiver faults will be logged as frames which can be monitored using the CAN Input node.

When Log Transceiver Faults is FALSE (disabled), the transceiver faults will not be logged as frames.

## Self Reception

This Boolean control indicates whether to enable the Self Reception feature to echo successfully transmitted CAN frames to be read using CAN Input node. The default is FALSE(disabled).

When Self Reception is TRUE (enabled), the transmits are echoed.

When Self Reception is FALSE (disabled), the transmits are not echoed.

## Single Shot Transmit

This Boolean control indicates whether to enable the Single Shot Transmit feature to prevent failed CAN frame transmissions from retrying. The default is FALSE (disabled).

When Single Shot Transmit is TRUE (enabled), single-shot is enabled. If a CAN frame is not transmitted successfully, the CAN controller will not retry.

When Single Shot Transmit is FALSE (disabled), the failed CAN frame transmissions are automatically retried.

#### Listen Only

This Boolean control indicates whether to enable the Listen Only feature for passive monitoring of the network. The default is FALSE (disabled).

When Listen Only is FALSE (disabled), you can transmit CAN messages normally using CAN Output. When CAN messages are received, those messages are acknowledged.

When Listen Only is TRUE (enabled), you cannot transmit CAN messages. When CAN messages are received, those messages are not acknowledged. The TCAN4550 CAN controller enters error passive state when Listen Only is enabled. Checking Listen Only enables passive monitoring of network traffic, which can be useful for debugging scenarios in which only one device exists on the network.

## **CAN Input**

Wait for a CAN frame to be received, then return that frame.

Complete the following steps to read from a CAN port using CAN Input.

- 1. Use the <u>Add Targets and Devices</u> dialog box to add the CAN module to your CompactRIO configuration. Right-click the CAN module in the <u>Project Explorer</u> window and select Properties to specify the configuration properties for the module.
- 2. Create an FPGA I/O item for CAN by right-clicking the FPGA target under My Computer in the Project Explorer window, selecting New»FPGA I/O, and then adding CANO to the FPGA I/O list. Refer to New FPGA I/O dialog box (FPGA Module) for more information about creating and adding FPGA I/O to your CompactRIO configuration.
- 3. Place an I/O Node from the FPGA I/O palette onto your FPGA VI diagram.
- 4. Right-click the I/O Node and select **Select FPGA I/O»CANO**.

- 5. Right-click the I/O Node and select **Change to Read** to use the I/O node for CAN Input.
- 6. Right-click the I/O Node and choose **Properties** to select the Data Type.

Start communication on the CAN port prior to using CAN Input. Enable Auto Start in the Module Configuration, or invoke the Start method to start communication.

The Input Timeout (ms) of the CAN Advanced Port Configuration dialog box specifies how long to wait for a new frame to be received. If you specify Input **Timeout (ms)** of 0, the CAN Input node will simply check to see if a new frame has arrived (non-blocking).

CAN Input can store the result of two received packets. Receiving an additional packet without calling CAN Input will cause an overflow error. NI recommends placing CAN Input in a loop that is executed when the device receives a data packet.

For information on how CAN Input arbitrates with other CAN nodes, refer to Arbitration.



**Note** You can add more than one CAN input port to the FPGA I/O node, and also add analog and digital inputs to the same FPGA I/O node by right-clicking the FPGA I/O node and selecting Add Element. Right-click the created I/O name and choose **Select FPGA** I/O to specify the I/O name. If you use more than one input per node, LabVIEW will execute them sequentially starting with the top input. If one input is blocked while waiting for the input, subsequent inputs will be delayed. For example, if you read an Analog or Digital Input and CANO in the same input node. that node will wait for a frame to be received on CANO and wait for Analog or Digital data to be available. Accessing the CANO port using a distinct CAN Input Node is more efficient.

## **Properties Dialog**

The **Data Type** selects the type for the CAN frame returned by the CAN Input node. The available values are **Cluster** (default) and **Array of U32**.

The benefits of using the **Cluster** data type are:

- Simpler block diagram (easy to use)
- Fast and efficient, if you limit use to the block diagram only (not front panel)

The benefit of the **Array of U32** data type, and handshaking integers to the host VI one at a time, is that it is faster for transfer to/from host VI.

Refer to the **Using Clusters and Arrays in LabVIEW FPGA** Application Note for more information on the use of clusters and arrays.

#### Node Inputs

|              | <b>Error In</b> Optional. Not shown by default. Right-click the node and select Error Terminals to enable.                                                                      |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Node Outputs |                                                                                                                                                                                 |
|              | Error Out Optional. Not shown by default. Right-click the node and select Error Terminals to enable.                                                                            |
|              | Unless you set the <b>Input Timeout (ms)</b> to −1 to wait indefinitely, you must use the error terminals to determine whether the CAN Input successfully received a CAN frame. |
|              | CANx If the <b>Data Type</b> is defined as <b>Cluster</b>                                                                                                                       |

U32

(default), the CAN frame is represented as a

**Timestamp High** 

cluster with the following elements:

U32

#### **Timestamp Low**

Timestamp of when the frame was received. The timestamp is acquired at the end of the CAN frame. The high and low U32 represent a single U64 timestamp. The timestamp is large enough to avoid handling rollover. The timestamp is zerobased (relative). The time starts ticking at zero when CAN communication starts. The resolution is 100

FU32

#### **Identifier**

Arbitration ID.

If bit 29 (20000000 hexadecimal) is clear, this ID uses the standard format (11bit). If bit 29 is set, this ID uses extended format (29-bit).

**■ U8** 

#### **Type**

Type of frame:

Data 0 Fram

e

Remo 1

te Fram

e

|            | Bus 6<br>Error                                                                                             |
|------------|------------------------------------------------------------------------------------------------------------|
|            | Trans <sup>7</sup><br>ceiver<br>Fault                                                                      |
|            | CAN 16<br>FD<br>Data<br>Fram<br>e                                                                          |
|            | CAN 24<br>FD+B<br>RS<br>Data<br>Fram<br>e                                                                  |
| ▶U8        | InfoA<br>Reserved for future<br>use.                                                                       |
| ▶ U8       | InfoB<br>Reserved for future<br>use.                                                                       |
| <b>▶U8</b> | Data Length For data frames, this indicates the number of bytes in Data (0–8 for CAN and 0–64 for CAN FD). |
|            | For remote frames, this indicates the number of bytes requested.                                           |
| [us]       | <b>Data</b> For data frames, this provides the data                                                        |

bytes. The array uses a fixed size of 64 bytes. Values above Data Length are not valid and should be ignored. For remote frames, the values contained in Data are not valid and should be ignored.

> If the **Data Type** is defined as Array of U32 the CAN frame is represented as the following Array of U32 values:



|                       | Timestamp<br>(lower U32) |                           |                          |                          |  |
|-----------------------|--------------------------|---------------------------|--------------------------|--------------------------|--|
| lo                    | Identifier               |                           |                          |                          |  |
| y<br>p                | T In In y fo fo p A B e  |                           |                          |                          |  |
| D<br>a<br>a<br>0      | t a                      | )<br>at<br>a[<br>.]       | D<br>at<br>a[<br>2]      | D<br>at<br>a[<br>3]      |  |
| D<br>a<br>a<br>4      | t a                      | )<br>at<br>a[<br>5]       | D<br>at<br>a[<br>6]      | D<br>at<br>a[<br>7]      |  |
| a<br>a<br>8           | t a                      | o<br>at<br>a[<br>0]       | D<br>at<br>a[<br>1<br>0] | D<br>at<br>a[<br>1<br>1] |  |
| D<br>a<br>a<br>1<br>2 | t a<br>[ a               | ot<br>at<br>a[<br>L<br>B] | D<br>at<br>a[<br>1<br>4] | D<br>at<br>a[<br>1<br>5] |  |
| D<br>a<br>a<br>1<br>6 | t a<br>[ a<br>1          | o<br>at<br>a[<br>L<br>']  | D<br>at<br>a[<br>1<br>8] | D<br>at<br>a[<br>1<br>9] |  |
| D<br>a<br>a<br>2<br>0 | t a                      | )<br>at<br>a[<br>2        | D<br>at<br>a[<br>2<br>2] | D<br>at<br>a[<br>2<br>3] |  |

| D                                         | D                                         | D                                         | D                                         |
|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|
| at                                        | at                                        | at                                        | at                                        |
| a[                                        | a[                                        | a[                                        | a[                                        |
| 2<br>4]                                   | 2<br>5]                                   | 2                                         | 2                                         |
| _                                         | _                                         | 6]                                        | 7]                                        |
| D                                         | D                                         | D                                         | D                                         |
| at<br>a[                                  | at<br>a[                                  | at<br>a[                                  | at<br>a[                                  |
| 2                                         | 2                                         | 3                                         | 3                                         |
| 8]                                        | 9]                                        | 0]                                        | 1]                                        |
| D                                         | D                                         | D                                         | D                                         |
| at                                        | at                                        | at                                        | at                                        |
| a[                                        | a[                                        | a[                                        | a[                                        |
| 3                                         | 3                                         | 3                                         | 3                                         |
| 2]                                        | 3]                                        | 4]                                        | 5]                                        |
| D                                         | D                                         | D                                         | D                                         |
| at                                        | at                                        | at                                        | at                                        |
| a[                                        | a[                                        | a[                                        | a[                                        |
| 3<br>6]                                   | 3<br>7]                                   | 3<br>8]                                   | 3<br>9]                                   |
|                                           |                                           | _                                         | _                                         |
|                                           |                                           |                                           |                                           |
| D                                         | D                                         | D                                         | D                                         |
| at                                        | at                                        | at                                        | at                                        |
| at<br>a[                                  | at<br>a[                                  | at<br>a[                                  | at<br>a[                                  |
| at                                        | at                                        | at                                        | at                                        |
| at<br>a[<br>4                             | at<br>a[<br>4                             | at<br>a[<br>4                             | at<br>a[<br>4                             |
| at<br>a[<br>4<br>0]                       | at<br>a[<br>4<br>1]                       | at<br>a[<br>4<br>2]                       | at<br>a[<br>4<br>3]                       |
| at<br>a[<br>4<br>0]<br>D<br>at<br>a[      | at<br>a[<br>4<br>1]<br>D<br>at<br>a[      | at<br>a[<br>4<br>2]<br>D<br>at<br>a[      | at<br>a[<br>4<br>3]<br>D<br>at<br>a[      |
| at<br>a[<br>4<br>0]<br>D<br>at<br>a[<br>4 | at<br>a[<br>4<br>1]<br>D<br>at<br>a[<br>4 | at<br>a[<br>4<br>2]<br>D<br>at<br>a[<br>4 | at<br>a[<br>4<br>3]<br>D<br>at<br>a[<br>4 |
| at<br>a[<br>4<br>0]<br>D<br>at<br>a[      | at<br>a[<br>4<br>1]<br>D<br>at<br>a[      | at<br>a[<br>4<br>2]<br>D<br>at<br>a[      | at<br>a[<br>4<br>3]<br>D<br>at<br>a[      |
| at a[ 4 0] D at a[ 4 4] D                 | at a[ 4 1] D at a[ 4 5] D                 | at a[ 4 2] D at a[ 4 6] D                 | at a[ 4 3] D at a[ 4 7] D                 |
| at a[ 4 0] D at a[ 4 4] D at              | at a[ 4 1] D at a[ 4 5] D at              | at a[ 4 2] D at a[ 4 6] D at              | at a[ 4 3] D at a[ 4 7] D at              |
| at a[ 4 0] D at a[ 4 4] D at a[           | at a[ 4 1] D at a[ 5] D at a[             | at a[ 4 2] D at a[ D at a[                | at a[ 4 3] D at a[ 7] D at a[             |
| at a[ 4 0] D at a[ 4 4] D at a[ 4         | at a[ 4 1] D at a[ 4 5] D at a[ 4         | at a[ 4 2] D at a[ 5                      | at a[ 4 3] D at a[ 4 7] D at a[ 5         |
| at a[ 4 0] D at a[ 4 4] D at a[ 4 8]      | at a[ 4 1] D at a[ 4 5] D at a[ 4 9]      | at a[ 4 2] D at a[ 5 0]                   | at a[ 4 3] D at a[ 4 7] D at a[ 5 1]      |
| at a[ 4 0] D at a[ 4 4] D at a[ 4 8] D    | at a[ 4 1] D at a[ 4 5] D at a[ 4 9] D    | at a[ 4 2] D at a[ 5 0] D                 | at a[ 4 3] D at a[ 4 7] D at a[ 5 1] D    |
| at a[ 4 0] D at a[ 4 4] D at a[ 4 8]      | at a[ 4 1] D at a[ 4 5] D at a[ 4 9]      | at a[ 4 2] D at a[ 5 0]                   | at a[ 4 3] D at a[ 4 7] D at a[ 5 1]      |
| at a[ 4 0] D at a[ 4 4] D at a[ 4 8] D at | at a[ 4 1] D at a[ 4 5] D at a[ 4 9] D at | at a[ 4 2] D at a[ 5 0] D at              | at a[ 4 3] D at a[ 5 1] D at              |
| at a[ 4 0] D at a[ 4 8] D at a[           | at a[ 4 1] D at a[ 4 9] D at a[           | at a[ 4 2] D at a[ 5 0] D at a[           | at a[ 4 3] D at a[ 5 1] D at a[           |

| D       | D       | D       | D       |
|---------|---------|---------|---------|
| at      | at      | at      | at      |
| a[      | a[      | a[      | a[      |
| 5       | 5       | 5       | 5       |
| 6]      | 7]      | 8]      | 9]      |
|         |         |         |         |
| D       | D       | D       | D       |
| D<br>at | D<br>at | D<br>at | D<br>at |
| -       | -       | -       | _       |
| at      | at      | at      | at      |

The meaning of each element is the same as the **Cluster** data type.

## **CAN Output**

Write a CAN frame to be transmitted.

Complete the following steps to write to a CAN port using CAN Output.

- 1. Use the <u>Add Targets and Devices</u> dialog box to add the CAN module to your CompactRIO configuration. Right-click the CAN module in the <u>Project Explorer</u> window and select Properties to specify the configuration properties for the module.
- 2. Create an FPGA I/O item for CAN by right-clicking the FPGA target under My Computer in the Project Explorer window, selecting New»FPGA I/O, and then adding CANO to the FPGA I/O list. Refer to New FPGA I/O dialog box (FPGA Module) for more information about creating and adding FPGA I/O to your CompactRIO configuration.
- 3. Place an I/O Node from the FPGA I/O palette onto your FPGA VI diagram.
- 4. Right-click the I/O Node and select **Select FPGA I/O»CANO**.
- 5. Right-click the I/O Node and select **Change to Write** to use the I/O node for CAN Output.

#### 6. Right-click the I/O Node and choose **Properties** to select the Data Type.

Start communication on the CAN port prior to using CAN Output. Enable Auto Start in the Module Configuration, or invoking the Start method to start communication.

The communication path from LabVIEW FPGA to the CAN port on the module is implemented as a FIFO. The CAN Output node waits for an available element in the FIFO, then writes the frame to the FIFO. If no other CAN frame exists in the FIFO, the CAN frame will begin to transmit immediately.

CAN Output does not wait for the requested transmit to complete on the network (acknowledgment). Call CAN Output followed by Wait on Transmit Complete (I/O Method) if you want to transmit CAN frames one at a time.

Write multiple frames to the output FIFO if you want to transmit CAN frames as fast as possible. The CAN module will submit these frames to the TCAN4550 controller as fast as possible.

When the output FIFO is full, the CAN Output node waits for an element to become available, then writes the frame to the FIFO. The Output Timeout (ms) of the CAN Advanced Port Configuration dialog box specifies how long to wait for a new element to become available, which occurs when a frame from a previous CAN Output transmits successfully onto the network. If you specify Output Timeout (ms) of 0, the CAN Output node returns an error status of TRUE (error) if a new element is not available (non-blocking). When an error is returned, you must attempt CAN Output of the same frame again at a later time.

In addition to the CAN Output node, the **Output Timeout (ms)** also applies to most methods and properties. For more information on the output path from LabVIEW FPGA to the CAN port, refer to Arbitration.



**Note** You can add more than one CAN output port to the FPGA I/O node, and also add analog and digital outputs to the same FPGA I/O node by right-clicking the FPGA I/O node and selecting Add Element. Right-click the created I/O name and select **Select FPGA I/O** to specify the I/O name. If you use more than one output per node, LabVIEW will execute them sequentially starting with the top output. If one



output is blocked while waiting for the output, subsequent outputs will be delayed.

**Note** The Transmit Packet Type may not exceed the mode set by the I/O Mode property.

## Properties Dialog

Selects the **Data Type** for the CAN frame written to the CAN Input node. The available values are **Cluster** (default) and **Array of U32**.

The benefits of using the **Cluster** data type are:

- Simpler block diagram (easy to use)
- Fast and efficient, if you limit use to the block diagram only (not front panel)

The benefits of the **Array of U32** data type, and handshaking integers to the host VI one at a time, are:

- Faster for transfer to/from host VI
- Fewer FPGA gates

Refer to the **Using Clusters and Arrays in LabVIEW FPGA** Application Note for more information on the use of clusters and arrays.

## Node Inputs

| <b>31</b> | •                | shown by default. Right-click the ct Error Terminals to enable.                                   |
|-----------|------------------|---------------------------------------------------------------------------------------------------|
| F-10      | CANx             |                                                                                                   |
|           | (default), the 0 | <b>pe</b> is defined as <b>Cluster</b><br>CAN frame is represented as a<br>ne following elements: |
|           | <u>U32</u> }     | Timestamp High Ignored. The transmit request always occurs                                        |

|      | as soon as possible (not timed).                                                                                                               |  |  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| U32) | Timestamp Low Ignored. The transmit request always occurs as soon as possible (not timed).                                                     |  |  |
| U321 | <b>Identifier</b> Arbitration ID.                                                                                                              |  |  |
|      | If bit 29 (20000000 hexadecimal) is clear, this ID uses the standard format (11-bit). If bit 29 is set, this ID uses extended format (29-bit). |  |  |
| 181  | <b>Type</b> Type of frame:                                                                                                                     |  |  |
|      | Data <sup>0</sup><br>Fram<br>e                                                                                                                 |  |  |
|      | Remo <sup>1</sup><br>te<br>Fram<br>e                                                                                                           |  |  |
|      | CAN 16<br>FD<br>Data<br>Fram<br>e                                                                                                              |  |  |
|      | CAN 24<br>FD+B<br>RS<br>Data<br>Fram<br>e                                                                                                      |  |  |

| U8 ) | InfoA<br>Reserved for future<br>use.                                                                        |
|------|-------------------------------------------------------------------------------------------------------------|
| U8 ) | InfoB<br>Reserved for future<br>use.                                                                        |
| US   | Data Length For data frames, this indicates the number of bytes in Data (0–8 for CAN and 0–64 for CAN FD.). |
|      | For remote frames, this indicates the number of bytes requested.                                            |
| [U8] | Data For data frames, this provides the data bytes. The array uses a fixed size of 64 bytes.                |

If the

Data Type
is defined as

Array of
U32
,
the CAN
frame is
represented
as the
following
Array of U32
values:



| t si g ni fic a nt b yt e |                     |                          | as t si g ni fic a nt b yt e           |
|---------------------------|---------------------|--------------------------|----------------------------------------|
| (up                       | pe                  | tan<br>r U3<br>tan       | 32)                                    |
|                           |                     | r U3                     |                                        |
| Ide                       | enti                | fier                     |                                        |
| Т<br>у<br>р<br>е          | In<br>fo<br>A       | In<br>fo<br>B            | D<br>at<br>a<br>L<br>e<br>n<br>gt<br>h |
| D<br>at<br>a[<br>0]       | D<br>at<br>a[<br>1] | D<br>at<br>a[<br>2]      | D<br>at<br>a[<br>3]                    |
| D<br>at<br>a[<br>4]       | D<br>at<br>a[<br>5] | D<br>at<br>a[<br>6]      | D<br>at<br>a[<br>7]                    |
| D<br>at<br>a[<br>8]       | D<br>at<br>a[<br>9] | D<br>at<br>a[<br>1<br>0] | D<br>at<br>a[<br>1<br>1]               |

| D D D D D D D D D D D D D D D D D D D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                           |                                                 |                                                 |                                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|
| a[       a[ <td< td=""><td>D</td><td>D</td><td>D</td><td>D</td></td<> | D                                         | D                                               | D                                               | D                                               |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                           |                                                 |                                                 |                                                 |
| 2] 3] 4] 5] D D D D at a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                           |                                                 |                                                 |                                                 |
| D D D D D D D D D D D D D D D D D D D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                           |                                                 |                                                 |                                                 |
| at at at at a[ a [ a [ a [ a [ a [ a [ a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                           |                                                 |                                                 |                                                 |
| a[       a[ <td< td=""><td></td><td></td><td></td><td></td></td<>     |                                           |                                                 |                                                 |                                                 |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                           |                                                 |                                                 |                                                 |
| 6] 7] 8] 9] D D D D at a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                           |                                                 |                                                 | _                                               |
| D D D D D D D D D D D D D D D D D D D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                           | 1                                               |                                                 |                                                 |
| at at at at a[                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                           |                                                 | _                                               |                                                 |
| a[ a[ a[ a[ 2 2 2 2 2 0] 1] 2] 3] D D D D D D D D D D D D D D D D D D D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                           |                                                 |                                                 |                                                 |
| 2 2 2 2 3 3 A A A A A A A A A A A A A A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                           |                                                 | at                                              |                                                 |
| 0] 1] 2] 3] D D D D at at at at at a[ a[ a[ a[ a[ 2 2 2 2 4] 5] 6] 7] D D D D at at at at at a[ a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | aL                                        |                                                 | aL                                              | aL                                              |
| D D D D D D D D D D D D D D D D D D D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                           |                                                 | 2                                               | 2                                               |
| at at at at a[                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                           |                                                 |                                                 | _                                               |
| 2 2 2 2 4] 5] 6] 7]  D D D D D at                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                           |                                                 | D                                               |                                                 |
| 2 2 2 2 4] 5] 6] 7]  D D D D D at                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | at                                        |                                                 | at                                              | at                                              |
| 4] 5] 6] 7] D D D D at at at at at a[                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | aL                                        |                                                 | aL                                              |                                                 |
| D D D D D D D D D D D D D D D D D D D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                           |                                                 |                                                 |                                                 |
| at at at at a[                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 4]                                        | 5]                                              | 6]                                              | 7]                                              |
| a[ a[ a[ a[ 2 2 3 3 8] 9] 0] 1] D D D D D D at                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                           |                                                 |                                                 |                                                 |
| 2 2 3 3 8 9 0 1] D D D D D at                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                           |                                                 |                                                 |                                                 |
| 8] 9] 0] 1] D D D D at at at at at a[ a[ a[ a[ a[ 3 3 3 3 3 2] 3] 4] 5] D D D D D at at at at at a[ a[ a[ a[ a[ 3 3 3 3 3 3 3 3 3 3 3 6] 7] 8] 9] D D D D D at at at at at a[ a[ a[ a[ a[ 4 4 4 4 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | at                                        | at                                              | at                                              | at                                              |
| D D D D D at                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | at<br>a[                                  | at<br>a[                                        | at<br>a[                                        | at<br>a[                                        |
| at at at at a[ a[ a[ a[ 3 3 3 3 3 2] 3] 4] 5]  D D D D D D at at at at a[ a[ a[ a[ a[ 3 3 3 3 3 6] 7] 8] 9]  D D D D D at                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | at<br>a[<br>2                             | at<br>a[<br>2                                   | at<br>a[<br>3                                   | at<br>a[<br>3                                   |
| a[ a[ a[ a[ 3 3 3 3 3 2] 3] 4] 5] D D D D D at at at at at at a[ a[ a[ a[ 3 3 3 3 3 6] 7] 8] 9] D D D D D at a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | at<br>a[<br>2<br>8]                       | at<br>a[<br>2<br>9]                             | at<br>a[<br>3<br>0]                             | at<br>a[<br>3<br>1]                             |
| 3 3 3 3 3 2] 3] 4] 5] D D D D D D D D D D D D D D D D D D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | at<br>a[<br>2<br>8]                       | at<br>a[<br>2<br>9]                             | at<br>a[<br>3<br>0]                             | at<br>a[<br>3<br>1]                             |
| 2] 3] 4] 5] D D D D at at at at at a[ a[ a[ a[ 3 3 3 3 6] 7] 8] 9] D D D D D at a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | at<br>a[<br>2<br>8]<br>D<br>at            | at<br>a[<br>2<br>9]<br>D<br>at                  | at<br>a[<br>3<br>0]<br>D<br>at                  | at<br>a[<br>3<br>1]<br>D<br>at                  |
| D D D D at at at at a[                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | at<br>a[<br>2<br>8]<br>D<br>at<br>a[      | at<br>a[<br>2<br>9]<br>D<br>at<br>a[            | at<br>a[<br>3<br>0]<br>D<br>at<br>a[            | at<br>a[<br>3<br>1]<br>D<br>at<br>a[            |
| at at at at a[ a[ a[ a[ 3 3 3 3 3 6] 7] 8] 9]  D D D D D D at at at at a[ a[ a[ 4 4 4 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | at<br>a[<br>2<br>8]<br>D<br>at<br>a[<br>3 | at<br>a[<br>2<br>9]<br>D<br>at<br>a[<br>3       | at<br>a[<br>3<br>0]<br>D<br>at<br>a[<br>3       | at<br>a[<br>3<br>1]<br>D<br>at<br>a[<br>3       |
| a[ a[ a[ a[ 3 3 3 3 3 6] 7] 8] 9] D D D D D at at at at a[ a[ a[ a[ 4 4 4 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | at<br>a[<br>2<br>8]<br>D<br>at<br>a[<br>3 | at<br>a[<br>2<br>9]<br>D<br>at<br>a[<br>3       | at<br>a[<br>3<br>0]<br>D<br>at<br>a[<br>3<br>4] | at<br>a[<br>3<br>1]<br>D<br>at<br>a[<br>3<br>5] |
| 3 3 3 9<br>6] 7] 8] 9]<br>D D D D<br>at at at at<br>a[ a[ a[ a[<br>4 4 4 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | at a[ 2 8] D at a[ 3 2] D                 | at a[ 2 9] D at a[ 3 3] D                       | at a[ 3 0] D at a[ 3 4] D                       | at a[ 3 1] D at a[ 3 5] D                       |
| 6] 7] 8] 9] D D D D at at at at at a[ a[ a[ 4 4 4 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | at a[ 2 8] D at a[ 3 2] D at              | at<br>a[<br>2<br>9]<br>D<br>at<br>a[<br>3<br>3] | at a[ 3 0] D at a[ 3 4] D at                    | at a[ 3 1] D at a[ 5] D at                      |
| D D D D at at at at a[ a[ a[ a[ 4 4 4 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | at a[ 2 8] D at a[ 3 2] D at a[           | at a[ 2 9] D at a[ 3 3] D at a[                 | at a[ 3 0] D at a[ 3 4] D at a[                 | at a[ 3 1] D at a[ 5] D at a[                   |
| at at at at<br>a[ a[ a[ a[<br>4 4 4 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | at a[ 2 8] D at a[ 2] D at a[ 3           | at a[ 2 9] D at a[ 3 3] D at a[ 3               | at a[ 3 0] D at a[ 3 4] D at a[ 3               | at a[ 3 1] D at a[ 3 5] D at a[ 3               |
| 4 4 4 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | at a[ 2 8] D at a[ 3 6]                   | at a[ 2 9] D at a[ 3 3] D at a[ 3 7]            | at a[ 3 0] D at a[ 3 4] D at a[ 3 8]            | at a[ 3 1] D at a[ 3 9]                         |
| 4 4 4 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | at a[ 2 8] D at a[ 3 6] D                 | at a[ 2 9] D at a[ 3 3] D at a[ 3 7] D          | at a[ 3 0] D at a[ 3 4] D at a[ 3 8] D          | at a[ 3 1] D at a[ 3 9] D                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | at a[ 2 8] D at a[ 3 6] D at              | at a[ 2 9] D at a[ 3 7] D at at                 | at a[ 3 0] D at a[ 3 4] D at a[ 3 8] D          | at a[ 3 1] D at a[ 3 9] D at                    |
| 0] 1] 2] 3]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | at a[ 2 8] D at a[ 3 6] D at a[           | at a[ 2 9] D at a[ 3 7] D at a[                 | at a[ 3 0] D at a[ 3 8] D at a[                 | at a[ 3 1] D at a[ 3 9] D at a[                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | at a[ 2 8] D at a[ 3 6] D at a[ 4         | at a[ 2 9] D at a[ 3 7] D at a[ 4               | at a[ 3 0] D at a[ 3 8] D at a[ 4               | at a[ 3 1] D at a[ 3 9] D at a[ 4               |

| D  | D  | D  | D  |
|----|----|----|----|
| at | at | at | at |
| a[ | a[ | a[ | a[ |
| 4  | 4  | 4  | 4  |
| 4] | 5] | 6] | 7] |
| D  | D  | D  | D  |
| at | at | at | at |
| a[ | a[ | a[ | a[ |
| 4  | 4  | 5  | 5  |
| 8] | 9] | 0] | 1] |
| D  | D  | D  | D  |
| at | at | at | at |
| a[ | a[ | a[ | a[ |
| 5  | 5  | 5  | 5  |
| 2] | 3] | 4] | 5] |
| D  | D  | D  | D  |
| at | at | at | at |
| a[ | a[ | a[ | a[ |
| 5  | 5  | 5  | 5  |
| 6] | 7] | 8] | 9] |
| D  | D  | D  | D  |
| at | at | at | at |
| a[ | a[ | a[ | a[ |
| 6  | 6  | 6  | 6  |
| 0] | 1] | 2] | 3] |

The meaning of each element is the same as the **Cluster** data type.

## Node Outputs

1966

#### **Error Out**

Optional. Not shown by default. Right-click the node and select Error Terminals to enable.

Unless you set the **Output Timeout (ms)** to -1 to wait indefinitely, you must use the error terminals to determine whether the CAN Output successfully submitted a CAN frame for transmit.

## Custom Baud Rate Dialog Box

This dialog configures advanced properties for the CAN port when in classical CAN or FD + BRS CAN mode. You can access this dialog from the <u>FPGA I/O Properties</u> <u>dialog box</u>.

#### Baud Rate

Specifies the custom Baud Rate for the transceiver when in classical CAN mode or when transmitting data before the BRS bit in CAN FD + BRS mode. The default Baud Rate is 500 kb/s.

#### Bit Timing Register

Specifies the custom CAN baud rate by setting the nominal Bit Timing and Prescaler register of the CAN controller. The fields are:

- Time quantum (Tq)—Programs the baud rate prescaler. Valid values are 25 to 12800, in increments of 0x19 (25 decimal). The default Tq is 50.
- Synchronization Jump Width (SJW)—Valid values are 0 to 127. The default SJW is 4. The actual hardware interpretation of this value is one more than the programmed value.
- Time Segment 1 (TSEG1)—Time segment before the sample point. Valid values are 1 to 0xFF (1 to 255 decimal). The default TSEG1 is 33. The actual hardware interpretation of this value is one more than the programmed value.
- Time Segment 2 (TSEG2)—Time segment after the sample point. Valid values are 0 to 0x7F (0 to 127 decimal). The default TSEG2 is 4. The actual hardware interpretation of this value is one more than the programmed value.

#### Sample Point

Specifies the custom sample point in classical CAN mode or when transmitting data before the BRS bit in CAN FD + BRS mode. The default sample point is 87.5%.

## Custom FD Baud Rate Dialog Box

This dialog box allows you to configure advanced properties for the CAN port when in FD or FD + BRS CAN mode. You can access this dialog from the FPGA I/O Properties Page.

#### FD Baud Rate

Specifies the custom Baud Rate for the transceiver when transmitting data after the BRS bit in FD + BRS CAN mode. The default FD Baud Rate is 500 kb/s.

## Bit Timing Register

Specifies the custom CAN FD baud rate with flexible data rate by setting the data Bit Timing and Prescaler register of the CAN controller. The fields are:

- Time quantum (Tq)—Programs the baud rate prescaler. Valid values are 25 to 800, in increments of 25 ns. The default Tq is 100.
- Synchronization Jump Width (SJW)—Valid values are 0 to 15. The default SJW is 3. The actual hardware interpretation of this value is one more than the programmed value.
- Time Segment 1 (TSEG1)—Time segment before the sample point. Valid values are 0 to 31. The default TSEG1 is 14. The actual hardware interpretation of this value is one more than the programmed value.
- Time Segment 2 (TSEG2)—Time segment after the sample point. Valid values are 0 to 15. The default TSEG2 is 3. The actual hardware interpretation of this value is one more than the programmed value.
- Transmitter Delay Compensation (TDC)—Enables or disables this feature.

Unchecked (default) TDC disabled TDC enabled Checked

- Transmitter Delay Compensation Offset (TDCO)—Defines the distance between the delay from transmit to receive point and secondary sample point. Valid values are 0 to 127. The default TDCO is 0.
- Transmitter Delay Compensation Filter Window Length (TDCF)—Defines the minimum value for the secondary sample point position. It is enabled when TDCF is greater than TDCO. Valid values are 0 to 127. The default TDCF is 0.

## Sample Point

Specifies the custom sample point in classical CAN FD mode or when transmitting data before the BRS bit in CAN FD + BRS mode. The default sample point is 80.0%.

#### I/O Properties

Complete the following steps to use an <u>FPGA I/O Property node</u> for CAN:

- 1. Use the <u>Add Targets and Devices</u> dialog box to add the CAN module to your CompactRIO configuration. Right-click the CAN module in the <u>Project Explorer</u> window and select <u>Properties</u> to specify the configuration properties for the module.
- 2. Create an FPGA I/O item for CAN by right-clicking the FPGA target under My Computer in the Project Explorer window, selecting New»FPGA I/O O»CANO to the FPGA I/O list. Refer to New FPGA I/O dialog box (FPGA Module) for more information about creating and adding FPGA I/O to your CompactRIO configuration.
- 3. Place an <u>I/O Property Node</u> from the FPGA I/O palette onto your FPGA VI diagram.
- 4. Right-click the I/O Property Node and select Select Item»CANO.
- 5. Right-click the I/O Property Node and choose **Select Property** to specify the appropriate property from the list of available CAN properties.

For information on how the <u>I/O Property Node</u> arbitrates with other CAN nodes, refer to <u>Arbitration</u>.

The description of each property includes the following table.

| Data type       | Permissions     | Read While<br>Stopped? | Read While Running? | Write While Stopped? | Write While Running? |
|-----------------|-----------------|------------------------|---------------------|----------------------|----------------------|
| <value></value> | <value></value> | <value></value>        | <value></value>     | <value></value>      | <value></value>      |

**Data type**: Shows the icon for the LabVIEW data type used for this property.

**Permissions**: Read, Write, or Read/Write. If the property is Read/Write, you can right-click the property in the node and select Change To Read or Change To **Write** to select the direction. Otherwise, only one direction is supported.

**Read While Stopped?**: Yes or No to indicate whether you can read the property while CAN communication is stopped.

Read While Running?: Yes or No to indicate whether you can read the property while CAN communication is running.

Write While Stopped?: Yes or No to indicate whether you can write the property while CAN communication is stopped.

Write While Running?: Yes or No to indicate whether you can write the property while CAN communication is running.

#### Baud Rate

| Data type | Permissions | Read While<br>Stopped? | Read While Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|------------------------|---------------------|----------------------|----------------------|
| U16 I     | Write       | No                     | No                  | Yes                  | No                   |

Each CAN baud rate selection configures the correspond Baud Rate for the transceiver when in classical CAN mode or when transmitting data before the BRS bit when in CAN FD + BRS mode. This property must always be set even when I/O Mode is set to CAN FD + BRS as the CAN FD + BRS protocol always has a portion of the frame that transfer in classical CAN mode.

The supported values in kb/s are 5.00, 6.150, 10.00, 12.5, 16.00, 20.00, 25.00, 31.25, 33.33, 40.00, 50.00, 62.50, 80.00, 83.33, 100.0, 125.0, 160.0, 200.0, 250.0, 400.0, 500.0, 800.0, and 1000. These bit fields are selected to create the desired baud rate with a default sample point of 87.5 percent.

This property converts the baud rate as selected into corresponds Synchronization Jump Width (SJW), Nominal Bit Rate Prescaler (BRP), Nominal Time Segment Before Sample Point (TSEG1), and Nominal Time Segment After Sample Point (TSEG2).

#### Baud Rate Advanced

| Data type |             | Permissions | Read While | Read While | Write While | Write While |
|-----------|-------------|-------------|------------|------------|-------------|-------------|
|           |             |             | Stopped?   | Running?   | Stopped?    | Running?    |
| Tq        | U16 I       | Write       | No         | No         | Yes         | No          |
| SJW       | <b>▶ U8</b> |             |            |            |             |             |
| TSEG1     |             |             |            |            |             |             |
| TSEG2     |             |             |            |            |             |             |

This property allows you to configure the custom CAN baud rate by setting the nominal bit timing and prescaler register of the CAN controller. You can set the following fields.

| Field                             | Description                                                                                                                        | Valid Values                                                                                                                                                        |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Time quantum (Tq)                 | Programs the baud rate prescal er                                                                                                  | 25 to 12,800 in increments of 0x<br>19 (25 decimal)<br>Note that the actual hardware i<br>nterpretation of this value is on<br>e more than the programmed v<br>alue |
| Synchronization Jump Width (S JW) | The maximum number of time quanta by which a bit sampling period can be extended or shor tened as a result of re-synchron ization. | 0 to 127                                                                                                                                                            |
| Time Segment 1 (TSEG1)            | The time segment before the sa mple point.                                                                                         | 1 to 0xFF (1 to 255 decimal)                                                                                                                                        |
| Time Segment 2 (TSEG2)            | The time segment after the sam ple point.                                                                                          | 0 to 0x7F (0 to 127 decimal)                                                                                                                                        |

The time quantum is calculated by the following formula.

Time quantum = (BRP + 1) \* 25

where

**BRP** = nominal bit rate prescaler value

Use the custom sample point calculator on the FPGA I/O Properties page under CANO»Baud Rate» < Custom > to determine the values to enter in this field to obtain the desired sample point.

Invalid Parameter or Error 65545 will be returned if you insert an invalid input.

#### FD Baud Rate

| Data type | Permissions | Read While Stopped? | Read While Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|---------------------|---------------------|----------------------|----------------------|
| U16 )     | Write       | No                  | No                  | Yes                  | No                   |

This property sets the baud rate for the transceiver when in FD + BRS CAN mode when transmitting data after the BRS bit. FD Baud Rate or FD Baud Rate Advanced property only need to be set when I/O mode is set to CAN FD + BRS.

The supported values in kb/s are 200, 250, 400, 500, 800, 1000, 1250, 1600, 2000, 2500, 4000 and 5000. These bit fields are selected to create the desired baud rate with a default sample point of 87.5%

This property converts the baud rate as selected into corresponds Time Quantum (TQ), Synchronization Jump Width (SJW), Data Time Segment Before Sample Point (TSEG1), Data Time Segment After Sample Point (TSEG2), Transmitter Delay Compensation Enabler(TDC) and Transmitter Delay Compensation Filter Window Length (TDCF).

#### FD Baud Rate Advanced

| Data type |             | Permissions | Read While<br>Stopped? | Read While Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|-------------|------------------------|---------------------|----------------------|----------------------|
| Tq<br>SJW | U161<br>U8  | Write       | No                     | No                  | Yes                  | No                   |
| TSEG1     |             |             |                        |                     |                      |                      |
| TSEG2     |             |             |                        |                     |                      |                      |
| TDC       | TF          |             |                        |                     |                      |                      |
| TDCF      | <b>▶ U8</b> |             |                        |                     |                      |                      |
| TDCO      |             |             |                        |                     |                      |                      |

This property allows you to configure the custom CAN FD baud rate by setting the nominal bit timing and prescaler register of the CAN controller. You can set the following fields.

| Field                                                          | Description                                                                                                                        | Valid Values                       |
|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Transmitter Delay Compensatio n (TDC)                          | Enables or disables this feature.                                                                                                  | FALSE = disabled<br>TRUE = enabled |
| Transmitter Delay Compensatio<br>n Offset (TDCO)               | Defines the distance between t<br>he delay from transmit to receiv<br>e point and secondary sample<br>point.                       | 0 to 127                           |
| Transmitter Delay Compensatio<br>n Filter Window Length (TDCF) | Defines the minimum value for<br>the secondary sample point po<br>sition. Enabled when TDCF is gr<br>eater than TDCO.              | 0 to 127                           |
| Time quantum (Tq)                                              | Programs the baud rate prescal er                                                                                                  | 25 to 800 in increments of 25 ns   |
| Time Segment 1 (TSEG1)                                         | The time segment before the sa mple point.                                                                                         | 0 to 31                            |
| Time Segment 2 (TSEG2)                                         | The time segment after the sam ple point.                                                                                          | 0 to 15                            |
| Synchronization Jump Width (S JW)                              | The maximum number of time quanta by which a bit sampling period can be extended or shor tened as a result of re-synchron ization. | nterpretation of this value is on  |

The time quantum is calculated by the following formula.

Time quantum = (BRP + 1) \* 25

where

**BRP** = nominal bit rate prescaler value

Use the custom sample point calculator on the FPGA I/O Properties page under CANO»FD Baud Rate»<Custom> to determine the values to enter in this field to obtain the desired sample point.

Invalid Parameter or Error 65545 will be returned if you insert an invalid input.

#### Comm State

| Data type | Permissions | Read While<br>Stopped? | Read While Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|------------------------|---------------------|----------------------|----------------------|
| ▶ U8      | Read        | Yes                    | Yes                 | N/A                  | N/A                  |

This property describes the current communication state of the CAN controller.

#### The values are:

| 0 | Error Active  |
|---|---------------|
| 1 | Error Passive |
| 2 | Bus Off       |

Use the Wait on Comm State Change method to detect changes in this property.

When you initially start communication, the CAN port will begin in the Error Active state as specified in the CAN standard (except when **Listen Only** is enabled). After bus errors cause a transition to Bus Off, that state will be retained until you call the Stop or Reset node. The Transmit Error Counter and Receive Error Counter will also reset to zero. If you are using the Stop node or Reset node with Auto Start disabled, you will need to call the Start node to continue communication in the Error Active state.

#### Listen Only

| Data type | Permissions | Read While<br>Stopped? | Read While<br>Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|------------------------|------------------------|----------------------|----------------------|
| TF        | Write       | No                     | No                     | Yes                  | No                   |

This property controls **Listen Only** mode for passive monitoring/logging.

FALSE disables **Listen Only** mode. Received frames are acknowledged, and frames can be transmitted using CAN Output.

TRUE enables **Listen Only** mode. The CAN port can only receive frames. The port does not transmit on the network. No acknowledgement is transmitted when a frame is received. When listen-only is enabled, the Comm State property begins in the Error Passive state.

CAN frame is transferred at a different (higher)

#### I/O Mode

| Data type   | Permissions | Read While<br>Stopped? | Read While Running? | Write While Stopped? | Write While Running? |
|-------------|-------------|------------------------|---------------------|----------------------|----------------------|
| <b>▶ U8</b> | Write       | No                     | No                  | Yes                  | No                   |

This property configures the CAN operating mode. The values are:

CAN(default) The default CAN 2.0 A/B standard I/O mode as defined in ISO 11898-1:2003. A fixed baud rate is used for transfer, and the payload length is limited to 8 bytes. **CAN FD** The CAN FD mode as specified in the CAN with Flexible Data-Rate specification, version 1.0. Payload lengths up to 64 are allowed, but they are transmitted at a single fixed baud rate. CAN FD + BRS The CAN FD as specified in the CAN with Flexible Data-Rate specification, version 1.0, with the optional Baud Rate Switching enabled. The same payload lengths as CAN FD mode are allowed; additionally, the data portion of the

## Input Timeout

| Data type   | Permissions | Read While<br>Stopped? | Read While<br>Running? | Write While Stopped? | Write While Running? |
|-------------|-------------|------------------------|------------------------|----------------------|----------------------|
| <b>▶U32</b> | Write       | No                     | No                     | Yes                  | No                   |

baud rate.

This property specifies the time to wait for the reading of CAN frame using CAN Input. The resolution is in milliseconds.

The timeout value of -1 (infinite wait) is supported.

#### Output Timeout (ms)

| Data type   | Permissions | Read While<br>Stopped? | Read While Running? | Write While Stopped? | Write While Running? |
|-------------|-------------|------------------------|---------------------|----------------------|----------------------|
| <b>JU32</b> | Write       | No                     | No                  | Yes                  | No                   |

This property specifies the time to wait for the writing of CAN frame using CAN Output. The resolution is in milliseconds.

Since this property set the wait for the pending transmission, use a timeout greater than zero. Using a timeout of 10,000 (ten seconds) is sufficient for most CAN baud rates (longer than a frame time).

The timeout value of -1 (infinite wait) is not supported, but you can use the largest positive I32 value, which provides a maximum of approximately 25 days.

#### Log Bus Errors

| Data type | Permissions | Read While<br>Stopped? | Read While<br>Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|------------------------|------------------------|----------------------|----------------------|
| TF        | Write       | No                     | No                     | Yes                  | Yes                  |

This property enables the logging of bus errors as frames that can be read using the CAN Input node.

The bus error frame is logged when the Texas Instruments TCAN4550 CAN controller detects a bus error.

FALSE indicates that the bus errors will not be logged and cannot be read using the CAN Input node (default). TRUE indicates that the bus errors will be logged as frames and can be read using the CAN Input node.

The bus error frame has the following format:

| Arbitration ID | 0                                                                                                        |
|----------------|----------------------------------------------------------------------------------------------------------|
| Data Length    | 5                                                                                                        |
| Туре           | 6                                                                                                        |
| Data           | Bytes 0—Comm State (see below) 1—Transmit Error Counter 2—Receive Error Counter 3—Detected Bus Error 4—X |
|                | 5—X                                                                                                      |

| 6—X |
|-----|
| 7—X |



#### Note X means Reserved or Don't Care.

The first data byte (Comm State) indicates the current communication state of the CAN controller. The states are:

- 0—Error Active
- 1—Error Passive
- 2—Bus Off

The fourth data byte (Detected Bus Error) indicates the error detected during a frame transmission. The states are:

- 0—None
- 1—Stuff
- 2—Form
- 3—Ack
- 4-Bit 1
- 5-Bit 0
- 6-CRC

## Log Transceiver Faults

| Data type | Permissions | Read While<br>Stopped? | Read While<br>Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|------------------------|------------------------|----------------------|----------------------|
| TF        | Write       | No                     | No                     | Yes                  | Yes                  |

This property enables the logging of transceiver faults as frames that can be read using the <u>CAN Input</u> node.

FALSE indicates that the transceiver faults will not be logged as frames (default). TRUE indicates that logging is enabled and the transceiver faults will be logged as frames which can be monitored using the <u>CAN Input</u> node.

#### The transceiver fault frame has the following format:

| Arbitration ID | 0                                                                   |
|----------------|---------------------------------------------------------------------|
| Data Length    | 1                                                                   |
| Туре           | 7                                                                   |
| Data           | Bytes<br>0—Transceiver fault (0=fault cleared, 1=fault pre<br>sent) |
|                | 1—X                                                                 |
|                | 2—X                                                                 |
|                | 3—X                                                                 |
|                | 4—X                                                                 |
|                | 5—X                                                                 |
|                | 6—X                                                                 |
|                | 7—X                                                                 |



Note X means Reserved or Don't Care.

## Self Reception

| Data type | Permissions | Read While<br>Stopped? | Read While<br>Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|------------------------|------------------------|----------------------|----------------------|
| TF        | Write       | No                     | No                     | Yes                  | Yes                  |

This property specifies whether to echo successfully transmitted CAN frames to be read using CAN Input. Each reception occurs just as if the frame were received from another CAN device. For self reception to operate properly, another CAN node must receive and acknowledge each transmit. If a transmitted frame is not successfully acknowledged, it is not echoed for input.

FALSE indicates transmits are not echoed (default), and TRUE indicates transmits are echoed.

## Single Shot Transmit

| Data type | Permissions | Read While Stopped? | Read While Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|---------------------|---------------------|----------------------|----------------------|
| TF        | Write       | No                  | No                  | Yes                  | Yes                  |

This property specifies whether to retry failed CAN frame transmissions.

FALSE indicates standard CAN behavior, where failed CAN frame transmissions are automatically retried (default), and TRUE indicates single-shot. With single-shot enabled, if a CAN frame is not transmitted successfully, the CAN controller will not retry.

#### Receive Error Counter

| Data type | Permissions | Read While<br>Stopped? | Read While<br>Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|------------------------|------------------------|----------------------|----------------------|
| ▶ U8      | Read        | Yes                    | Yes                    | N/A                  | N/A                  |

This property provides access to the CAN controller Receive Error Counter defined by the CAN standard.

#### Transmit Error Counter

| Data type   | Permissions | Read While<br>Stopped? | Read While<br>Running? | Write While Stopped? | Write While Running? |
|-------------|-------------|------------------------|------------------------|----------------------|----------------------|
| <b>▶ U8</b> | Read        | Yes                    | Yes                    | N/A                  | N/A                  |

This property provides access to the CAN controller Transmit Error Counter defined by the CAN standard.

#### Transceiver Mode

| Data type | Permissions | Read While<br>Stopped? | Read While Running? | Write While Stopped? | Write While Running? |
|-----------|-------------|------------------------|---------------------|----------------------|----------------------|
| U8 I      | Read/Write  | No                     | Yes                 | No                   | Yes                  |

This property sets the mode for the CAN transceiver, as well as the associated mode in the TCAN4550 CAN controller.

The values are:

0 Normal Sleep

The Sleep mode places the TCAN4550 and the CAN transceiver into a low-power state. This low-power state has no effect on LabVIEW FPGA hardware. The Sleep mode can be set only when the CAN controller is running (not when stopped).

A local wakeup occurs when you set Transceiver Mode from Sleep back to Normal.

A **remote wakeup** occurs when a remote node transmits a CAN frame (referred to as the wakeup frame). The wakeup frame wakes up the transceiver and CAN controller chip. The wakeup frame is not received or acknowledged by the TCAN4550 CAN controller. When the wakeup frame ends, the CAN port enters Normal mode, and again receives and transmits CAN frames. If the node that transmitted the wakeup frame did not detect an acknowledgment (such as if other nodes were also waking), it will retry the transmission, and the retry will be received by the CAN port.

Once the transceiver is set into Sleep mode, you can invoke the Wait On Transceiver Wakeup method to determine when a remote wakeup occurs.

#### Reset

Reset the CAN port to the same state as when the FPGA VI started running.

This method resets the TCAN4550, and then restores all properties to their default values. If you enable Auto Start in the tool, this method will also re-start communication.

When a CAN controller enters the Bus Off state (see Comm State property), it no longer communicates. By performing a complete reset of the TCAN4550, this method recovers from the Bus Off state.

This method also clears the output FIFO as well as any pending CAN node (including all Wait methods). The reset affects only the specified CAN port, and has no effect on the other CAN port of the module.

### Node Inputs



Optional. Not shown by default. To enable, right-click the node and select Error Terminals.

## Node Outputs

| PET | Error Out                                                                                   |
|-----|---------------------------------------------------------------------------------------------|
|     | Optional. Not shown by default. To enable, right-click the node and select Error Terminals. |

#### Start

Start communication.

Cases for using this method, as opposed to enabling **Auto Start** in Module Configuration:

- Change configuration properties within the diagram (such as the Listen Only property)
- Auto-baud algorithms (must Stop/Start to set the baud rate for each attempt)
- Start CAN communication on a trigger (analog or digital input)

## Node Inputs

| 551 | Error In                                                                                    |
|-----|---------------------------------------------------------------------------------------------|
|     | Optional. Not shown by default. To enable, right-click the node and select Error Terminals. |

### Node Outputs

| No. | Error Out                                                                                   |
|-----|---------------------------------------------------------------------------------------------|
|     | Optional. Not shown by default. To enable, right-click the node and select Error Terminals. |

### Stop

Stop communication.

This method also clears the output FIFO as well as any pending CAN node (including all Wait methods).

### Node Inputs

| P. 1 | Error In                                                                                    |
|------|---------------------------------------------------------------------------------------------|
|      | Optional. Not shown by default. To enable, right-click the node and select Error Terminals. |

#### Node Outputs

| Error Out                                                                                   |
|---------------------------------------------------------------------------------------------|
| Optional. Not shown by default. To enable, right-click the node and select Error Terminals. |

#### **Abort Transmit**

Abort a pending CAN frame transmission.

Since the determinism of CAN depends on the prioritization of frames based on ID, the TCAN4550 CAN controller allows you to abort a pending transmit to replace it with a higher priority ID.

When implementing protocols that require abort, you must ensure that only one transmit is pending. Call Wait on Transmit Complete before (or after) each call to **CAN Output**. If more than one transmit is pending at the time **Abort Transmit** is called, the Transmit Success Boolean could refer to any one of those pending frames.

## Node Inputs

| EH | Error In                                                                                   |
|----|--------------------------------------------------------------------------------------------|
|    | Optional. Not shown by default. Right-click the node and select Error Terminals to enable. |

## Node Outputs

| Indicates whether the pending transmit was successfully aborted, or transmitted on the network before it could be aborted.  If the pending transmit aborted successfully, this returns FALSE.  If the pending frame transmitted successfully on the network prior to the <b>Abort Transmit</b> , this returns TRUE. |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Error Out Optional. Not shown by default. Right-click the node and select Error Terminals to enable.                                                                                                                                                                                                                |

## Wait on Comm State Change

Wait for a change in the communication state of the CAN port (<u>Comm State</u> property). This enables you to handle CAN communication state changes in a separate loop from your main CAN Input/Output loop.

If the **Comm State** property changes before you call Wait (relative to the previous Wait), the current Wait returns immediately. The **Comm State** is not considered to be changed when you first Start, and it does not change after Stop.

This method returns an error if invoked while communication is stopped.

## Node Inputs

|              | Error In  Optional. Not shown by default. To enable, right-click the node and select Error Terminals.   |
|--------------|---------------------------------------------------------------------------------------------------------|
| <b>132</b> ) | Timeout  Specifies the time to wait for the communication state to change.                              |
|              | The resolution is in milliseconds.                                                                      |
|              | The special <b>Timeout</b> of 0 is used to poll for the changed state. If <b>Comm State</b> has changed |

| from the previous call to Wait, the <b>Timed Out?</b> Boolean is FALSE. If <b>Comm State</b> has not changed, the <b>Timed Out?</b> Boolean is TRUE. |
|------------------------------------------------------------------------------------------------------------------------------------------------------|
| The <b>Timeout</b> value of −1 (infinite wait) is supported.                                                                                         |

### Node Outputs

|            | Error Out Optional. Not shown by default. To enable, right-click the node and select Error Terminals. |
|------------|-------------------------------------------------------------------------------------------------------|
| <b>PTF</b> | Timed Out? Indicates a timeout.                                                                       |
|            | When <b>Timed Out?</b> is TRUE, the error cluster indicates success (not a timeout error).            |
| T ()       | Comm State                                                                                            |
|            | Returns the new value of the <b>Comm State</b> property.                                              |

## Wait on Transceiver Wakeup

Wait for the Transceiver Mode property to change from Sleep to Normal mode due to a remote wakeup (bus activity) or local wakeup. A local wakeup occurs if you use the I/O Property node to set Transceiver Mode property back to Normal.

If a wakeup occurs before you call Wait (relative to the previous Wait), the current Wait returns immediately. The wakeup is not considered to have occurred when you first Start, and it does not occur after Stop.

This method returns an error if invoked while communication is stopped.

### Node Inputs

| Error In |
|----------|

|      | Optional. Not shown by default. To enable, right-click the node and select Error Terminals.                                                                                                                                                         |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T321 | Timeout Specifies the time to wait for the Transceiver Mode to change to Normal.                                                                                                                                                                    |
|      | The resolution is in milliseconds.                                                                                                                                                                                                                  |
|      | The special <b>Timeout</b> of 0 is used to poll for the wakeup. If a wakeup has occurred since the previous call to Wait, the <b>Timed Out?</b> Boolean is FALSE. If <b>Transceiver Mode</b> is still Sleep, the <b>Timed Out?</b> Boolean is TRUE. |
|      | The <b>Timeout</b> value of -1 (infinite wait) is supported.                                                                                                                                                                                        |

### Node Outputs

| P. T. C. | Error Out Optional. Not shown by default. To enable, right-click the node and select Error Terminals. |
|----------|-------------------------------------------------------------------------------------------------------|
| FTF      | Timed Out? Indicates a timeout.                                                                       |
|          | When <b>Timed Out?</b> is TRUE, the error cluster indicates success (not a timeout error).            |

## Wait on Transmit Complete

Wait for **all** frames written to CAN Output to complete transmission. You typically use this to determine when all frames have been acknowledged.

If all transmits are complete before you call Wait (relative to the previous Wait), the current wait returns immediately. All transmits are considered complete after you first Start. This method returns an error if invoked while communication is stopped.

## Node Inputs

|      | Error In Optional. Not shown by default. To enable, right-click the node and select Error Terminals.                                                                                                                                                                                                  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T321 | <b>Timeout</b> Specifies the time to wait for all frames to complete transmission.                                                                                                                                                                                                                    |
|      | The resolution is in milliseconds.  The special <b>Timeout</b> of 0 is used to poll for transmit complete status. If all transmits are complete, the <b>Timed Out?</b> Boolean is FALSE. If one or more transmissions are pending (not successful or aborted), the <b>Timed Out?</b> Boolean is TRUE. |
|      | The <b>Timeout</b> value of −1 (infinite wait) is supported.                                                                                                                                                                                                                                          |

## Node Outputs

|     | Error Out Optional. Not shown by default. To enable, right-click the node and select Error Terminals. |
|-----|-------------------------------------------------------------------------------------------------------|
| PTF | Timed Out? Indicates a timeout.                                                                       |
|     | When <b>Timed Out?</b> is TRUE, the error cluster indicates success (not a timeout error).            |

## sbRIO-9603

Single-Board Reconfigurable I/O (DIO), 1 RS-232 Serial port, 1 CAN port, Artix-7 75T FPGA

### sbRIO-9603 Pinouts

## Connector J3, CAN Port



## Connector J4, Serial Port



Refer to the <u>CompactRIO Related Documentation</u> for further information about CompactRIO documentation.

## **Related Topics**

Configuring a Project with Connected Hardware Configuring a Project with Offline Hardware **RT Watchdog VIs** 

sbRIO-9607

Single-Board Reconfigurable I/O (DIO), 1 RS-232 Serial port, 1 CAN port, Zynq-7020 **FPGA** 

## sbRIO-9607 Pinouts

### Connector W500, CAN Port



## Connector W501, Serial Port



Refer to the <u>CompactRIO Related Documentation</u> for further information about CompactRIO documentation.

## **Related Topics**

Configuring a Project with Connected Hardware
Configuring a Project with Offline Hardware
RT Watchdog VIs

sbRIO-9608

Single-Board Reconfigurable I/O (DIO), 1 RS-232 Serial port, 1 CAN port, Artix-7 200T FPGA

### sbRIO-9608 Pinouts

## Connector J3, CAN Port



## Connector J4, Serial Port



Refer to the CompactRIO Related Documentation for further information about CompactRIO documentation.

## **Related Topics**

Configuring a Project with Connected Hardware
Configuring a Project with Offline Hardware
RT Watchdog VIs

sbRIO-9609

Single-Board Reconfigurable I/O (DIO), 1 RS-232 Serial port, 1 CAN port, Artix-7 200T FPGA

### sbRIO-9609 Pinouts

### Connector J3, CAN Port



#### Connector J4, Serial Port



Refer to the CompactRIO Related Documentation for further information about CompactRIO documentation.

## **Related Topics**

Configuring a Project with Connected Hardware Configuring a Project with Offline Hardware **RT Watchdog VIs** 

sbRIO-9627

Single-Board Reconfigurable I/O (MIO), 16 AI channels, 4 AO channels, 4 3.3 V DIO channels, 2 RS-232 Serial ports, 1 RS-485 Serial port, 1 CAN port, RIO mezzanine card connector, Zynq-7020 FPGA

### Software Reference (?)

FPGA Interface

# sbRIO-9627 Pinouts

## Connector J5, MIO



| GND  | 1  | 2  | Al0  |
|------|----|----|------|
| Al8  | 3  | 4  | GND  |
| Al9  | 5  | 6  | Al1  |
| GND  | 7  | 8  | Al2  |
| Al10 | 9  | 10 | GND  |
| Al11 | 11 | 12 | Al13 |
| GND  | 13 | 14 | Al14 |
| Al12 | 15 | 16 | GND  |
| Al13 | 17 | 18 | Al5  |
| GND  | 19 | 20 | Al6  |
| Al14 | 21 | 22 | GND  |
| Al15 | 23 | 24 | Al7  |
| GND  | 25 | 26 | GND  |
| GND  | 27 | 28 | AO0  |
| GND  | 29 | 30 | AO1  |
| GND  | 31 | 32 | AO2  |
| GND  | 33 | 34 | AO3  |
| GND  | 35 | 36 | NC   |
| GND  | 37 | 38 | NC   |
| GND  | 39 | 40 | NC   |
| GND  | 41 | 42 | NC   |
| GND  | 43 | 44 | DIO0 |
| GND  | 45 | 46 | DIO1 |
| GND  | 47 | 48 | DIO2 |
| GND  | 49 | 50 | DIO3 |

## Connector W1, CAN Port



| NC       | 1 | 2  | CAN1_L  |
|----------|---|----|---------|
| V- (GND) | 3 | 4  | NC      |
| SHIELD   | 5 | 6  | V-(GND) |
| CAN1_H   | 7 | 8  | NC      |
| NC       | 9 | 10 | SHIELD  |

## Connectors W2 and W4, RS-232 Serial Ports



## Connector W3, RS-485 Serial Port



## **Related Topics**

Configuring a Project with Connected Hardware Configuring a Project with Offline Hardware **RT Watchdog VIs** 

sbRIO-9627 (FPGA Interface)

Single-Board Reconfigurable I/O (MIO)

16 AI channels, 4 AO channels, 4 3.3 V DIO channels, 2 RS-232 Serial ports, 1 RS-485 Serial port, 1 CAN port, RIO mezzanine card connector, Zynq-7020 FPGA

## FPGA I/O Node

You can use an FPGA I/O Node, configured for reading and writing, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal               | Description                                                                                                                                                                                                                                |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Connector0/Al <b>x</b> | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. The sbRIO-9627 has AI channels 0 to 15.                                                                                                                       |
| Connector0/AOx         | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. The sbRIO-9627 has AO channels 0 to 3.                                                                                                                       |
| Connector0/DIOx        | Digital input/output channel <b>x</b> , where <b>x</b> is the n umber of the channel. The sbRIO-9627 has chan nels 0 to 3. Use the FPGA I/O Node or the <u>Set Output Data</u> or <u>Set Output Enable</u> method to acces s this channel. |

### **Arbitration**

You can configure the arbitration settings for the DIO channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

### I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

| Method | Description                                                                       |
|--------|-----------------------------------------------------------------------------------|
| ·      | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |
| ·      | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |

#### **Module Methods**

This device does not support any module methods.

## **Properties**

Use the FPGA I/O Property Node to access the following properties for this device.

| Property      | Description                                                                                                                                                                                                               |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Terminal Mode | Sets the terminal mode for a channel as RSE (ref erenced single-ended) or DIFF (differential). This property overwrites the value you configure in the FPGA I/O Properties dialog box.                                    |
| Voltage Range | Sets the input range for a channel as $\pm 10 \text{ V}$ , $\pm 5 \text{ V}$ , $\pm 2 \text{ V}$ , or $\pm 1 \text{ V}$ . This property overwrites the value you configure in the <b>FPGA I/O Properties</b> dial og box. |

## Single-Cycle Timed Loop

This device supports the single-cycle Timed Loop for digital I/O only. Configure the number of output synchronizing registers for the channels of this device in the Advanced Code Generation page of the FPGA I/O Properties dialog box. Configure the number of input synchronizing registers for the channels of this device in the Advanced Code Generation page of the FPGA I/O Node Properties dialog box.

#### sbRIO-9628

Single-Board Reconfigurable I/O (MIO and DIO), 16 AI channels, 4 AO channels, 4 5 V DIO channels, 2 RS-232 Serial ports, 1 RS-485 Serial port, 1 CAN port, RIO mezzanine card connector, Artix-7 100T FPGA

## Software Reference (?)

FPGA Interface

# sbRIO-9628 Pinouts

## Connector J2, MIO





## Connector J3, CAN Port



#### Connectors J4 and J6, RS-232 Serial Ports



### Connector J5, RS-485 Serial Port



## **Related Topics**

Configuring a Project with Connected Hardware Configuring a Project with Offline Hardware RT Watchdog VIs

sbRIO-9628 (FPGA Interface)

Single-Board Reconfigurable I/O (MIO and DIO), 16 AI channels, 4 AO channels, 4 5 V DIO channels, 2 RS-232 Serial ports, 1 RS-485 Serial port, 1 CAN port, RIO mezzanine card connector, Artix-7 100T FPGA

## FPGA I/O Node

You can use an FPGA I/O Node, configured for reading and writing, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal             | Description                                                                                                            |
|----------------------|------------------------------------------------------------------------------------------------------------------------|
| Conn0_AI/AI <b>x</b> | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. The sbRIO-9628 has AI channels 0 to 15.   |
| Conn0_AO/AOx         | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. The sbRIO-9628 has AO channels 0 to 3.   |
| Conn0_DIO0-3/DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the channel number. The sbRIO-9628 has DIO channel s 0 to 3. |
| Conn0_DIO0-3/DIO3:0  | Digital port consisting of channels 0 through 3.<br>Channel 3 signifies the MSB and channel 0 signifies the LSB.       |

### **Arbitration**

You cannot configure arbitration settings for analog input and analog output channels of this device. Analog input and analog output channels on this device only support the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration.

You can configure the arbitration settings for digital output channels on this device in the <u>Advanced Code Generation</u> page on the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is Never Arbitrate.

Digital input channels on this device only support the <u>Never Arbitrate</u> option for arbitration. You cannot configure arbitration settings for digital input channels on this device.

## I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

| Method            | I/OType | Description                                                                                                                                                    |
|-------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data   | DIO     | Refer to the <u>FPGA I/O Method N</u> <u>ode</u> topic for a description of th is method.                                                                      |
| Set Output Enable | DIO     | Sets the line direction of the dig ital channel or the digital port. Refer to the <u>FPGA I/O Method N</u> <u>ode</u> topic for a description of th is method. |

## **Module Methods**

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method       | І/О Туре | Description                                                                                  |
|--------------|----------|----------------------------------------------------------------------------------------------|
| Check Status | DIO      | Returns a Boolean value that in dicates whether the DIO modul e is ready for I/O operations. |

# **I/O Properties**

Use the FPGA I/O Property Node to access the following properties for this device.

| Property      | І/ОТуре | Description                                                                                                                                                                                                                                         |
|---------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Terminal Mode | AI      | Sets the terminal mode for a channel as RSE (referenced single-ended) or DIFF (differential). This property overwrites the value you configure in the <b>Module Properties</b> dialog box. You cannot configure channels 8 through 15 to DIFF mode. |
| Voltage Range | Al      | Sets the input range for a chann el as ±10 V, ±5 V, ±2 V, or ±1 V. Th is property overwrites the value you configure in the Module P roperties dialog box.                                                                                          |
| LSB Weight    | AO      | Returns the LSB weight in nV/LS<br>B for the channel. Use this valu<br>e to <u>convert AO data</u> if you set t                                                                                                                                     |

|        |    | he Calibration Mode to Raw in the Module Properties dialog box.                                                                                                       |
|--------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset | AO | Returns the calibration offset in nV for the channel. Use this val ue to convert AO data if you set the Calibration Mode to Raw in the Module Properties dial og box. |

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following properties for this device.

| Property                 | І/ОТуре | Description                                                                                                                                                                                          |
|--------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight (±10 V range) | AI      | Returns the LSB weight in pV/LS B for the ±10 V range. Use this v alue to <u>convert AI data</u> if you se t the <b>Calibration Mode</b> to <b>Ra</b> w in the <b>Module Properties</b> d ialog box. |
| LSB Weight (±5 V range)  | Al      | Returns the LSB weight in pV/LS B for the ±5 V range. Use this value to convert AI data if you set the Calibration Mode to Raw in the Module Properties dialog box.                                  |
| LSB Weight (±2 V range)  | Al      | Returns the LSB weight in pV/LS B for the ±2 V range. Use this value to convert AI data if you set the Calibration Mode to Raw in the Module Properties dialog box.                                  |
| LSB Weight (±1 V range)  | AI      | Returns the LSB weight in pV/LS B for the ±1 V range. Use this value to <u>convert AI data</u> if you set the <b>Calibration Mode</b> to <b>Raw</b> in the <b>Module Properties</b> dialog box.      |

| Offset (±10 V range) | Al | Returns the calibration offset in nV for the ±10 V range. Use this value to convert AI data if you s et the Calibration Mode to R aw in the Module Properties dialog box.  |
|----------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset (±5 V range)  | Al | Returns the calibration offset in nV for the ±5 V range. Use this v alue to convert AI data if you se t the Calibration Mode to Ra w in the Module Properties d ialog box. |
| Offset (±2 V range)  | Al | Returns the calibration offset in nV for the ±2 V range. Use this v alue to convert AI data if you se t the Calibration Mode to Ra w in the Module Properties d ialog box. |
| Offset (±1 V range)  | Al | Returns the calibration offset in nV for the ±1 V range. Use this v alue to convert AI data if you se t the Calibration Mode to Raw in the Module Properties d ialog box.  |

## Single-Cycle Timed Loop

This device supports the single-cycle Timed Loop for digital I/O only. Configure the number of output synchronizing registers or input synchronizing registers for the channels on this device in the Advanced Code Generation page of the FPGA I/O Properties dialog box.

The Set Output Enable method node is not supported in the single-cycle Timed Loop. When writing to a DIO I/O node in a single-cycle Timed Loop, the I/O node will not change the DIO line directions. To set the line directions to output when writing to the DIO channels in a single-cycle Timed Loop, either configure the default line directions to output in the Module Properties dialog box, or use the Set Output Enable method node outside a single-cycle Timed Loop.

This device supports the Number of Synchronizing Registers for Output Data synchronizing register option when used in SCTL output. This option supports the same functionality as the Number of Synchronizing Registers for Output Data option described in the Advanced Code Generation FPGA I/O Properties Page (FPGA Module) topic, with the exception that you can use this option only in a single-cycle Timed Loop. You can implement either 0 or 1 synchronizing registers inside the single-cycle Timed Loop, however, if you configure 0 synchronizing registers outside of the single-cycle Timed Loop, the FPGA VI implements 1 synchronizing register by default.

When the device is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

Converting Analog Input Values for the sbRIO-9628/9629/9638 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the **Module Properties** dialog box for the onboard analog input module if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data for the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node returns uncalibrated, binary values. These binary values can be converted to calibrated volts by applying the calibration constants. The conversion of binary data to calibrated data can be done in the host VI.

Using an Equation to Convert and Calibrate Values

You can use the following equation in the host VI to convert binary analog input values to calibrated volts:

**Volts** = (**Binary Value** × **LSB Weight** - **Offset**) where

Binary Value is the signed value returned by the FPGA I/O Node

**LSB Weight** is the value returned by the LSB Weight property **Offset** is the value returned by the Offset property.

The LSB Weight property is returned in units of pV/LSB. The Offset property is returned in units of nV.

To convert to calibrated volts, use the FPGA I/O Property Node to read the LSB Weight and Offset properties for the desired input range. If you do not want to read the LSB Weight and Offset values from the module, you can convert to uncalibrated engineering units by using the following typical values for **Offset** and **LSB Weight**:

#### Offset = 0 V

The typical **LSB Weight** depends on the input range. See the table below:

| Input Range | Typical LSB Weight |
|-------------|--------------------|
| ±10 V       | 320 μV/LSB         |
| ±5 V        | 160 μV/LSB         |
| ±2 V        | 64 μV/LSB          |
| ±1 V        | 32 μV/LSB          |

Converting Analog Output Values for the sbRIO-9628/9629/9638 (FPGA Interface)

Set the Calibration Mode to Calibrated in the Module Properties dialog box for the onboard analog output module if you want the FPGA I/O Node to accept fixed-point data in units of volts for the module. If you set the **Calibration Mode** to Raw, the FPGA I/O Node accepts only binary values. You must convert output voltage values to binary values using the calibration constants before you write

them to the FPGA I/O node. The conversion of voltage values to binary values can be done in the host VI.

Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

**Binary Value** = (**Voltage Value** - **Offset**) ÷ **LSB Weight** where

**Voltage Value** is the value you write to the FPGA I/O Node **Voltage Value** is the voltage in V that you want the channel to output **Offset** is the value returned by the Offset property **LSB Weight** is the value returned by the LSB Weight property.

The **LSB Weight** property is returned in units of nV/LSB. The **Offset** property is returned in units of nV.

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following typical values for **Offset** and **LSB Weight**:

Offset = 0 VLSB Weight =  $320 \mu\text{V/LSB}$ 

Module Properties Dialog Box for the sbRIO-9628/9629/9638 (FPGA Interface)

Right-click an onboard I/O module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure an onboard I/O module.

For all onboard I/O modules, this dialog box includes the following components:

- Name—Specifies the name of the onboard I/O module, which appears in the Project Explorer window. LabVIEW assigns a default name to the module based on the connector number and channel numbers. You can use this field to give the onboard module a descriptive name.
- Module Type—Specifies the type of module. You cannot change this option.
- Location—Specifies the connector containing the onboard module's channels. You cannot change this option.

The onboard AI module's dialog box also includes the following:

- Calibration Mode—Sets the calibration mode for the onboard module. Select Calibrated if you want the FPGA I/O Node to return calibrated, fixedpoint data for the module in units of volts. The <u>fixed-point</u> data is signed, with a word length of 24 bits and an integer word length of 5 bits. Select Raw if you want the FPGA I/O Node to return uncalibrated, binary data for the module. If you select Raw, you must convert and calibrate the analog input values in the host VI. The default is **Calibrated**.
- Channel Configuration—Specifies the input range for each channel.
  - Channels—Specifies the channel(s) for which you want to select the input range.
  - Input Range—Specifies the input range for the selected channel(s) as  $\pm 10 \text{ V}, \pm 5 \text{ V}, \pm 2 \text{ V}, \text{ or } \pm 1 \text{ V}.$
  - Terminal Mode—Specifies the terminal mode for the selected channel(s) as RSE (referenced single-ended) or DIFF (differential).
- Minimum Time Between Conversions—Specifies the minimum time between conversions in µs. This time determines the shortest possible time between any two conversions. For channels sampled within the same FPGA I/O Node, the time you set determines the exact time between conversions. For channels sampled within separate FPGA I/O Nodes or for conversions

caused by looping on an FPGA I/O Node, the time you set may be less than the actual time between conversions. However, the minimum time you set is never greater than the time between conversions. If the application tries to execute an FPGA I/O Node faster than the specified minimum time between conversions, the conversion is delayed until the minimum time you set is satisfied. The default minimum time between conversions is 8  $\mu s$ . The accuracy specifications in the sbRIO-9638 hardware documentation on ni.com/manuals are based on this default value. If you set the minimum time between conversions to at least 8  $\mu s$ , the accuracy of the module is not affected. If you set the minimum time between conversions to less than 8  $\mu s$ , the accuracy of the onboard module degrades if you sample data from multiple channels.

The onboard AO module's dialog box also includes the following:

• Calibration Mode—Sets the calibration mode for the onboard module. Select Calibrated if you want the FPGA I/O Node to accept fixed-point data in units of volts when writing to the module. The fixed-point data is signed, with a word length of 20 bits and an integer word length of 5 bits. Select Raw if you want the FPGA I/O Node to accept calibrated, binary data when writing to the module. If you select Raw, you must convert the analog output values in the host VI before you write them to the module. The default is Calibrated.

The onboard DIO module's dialog box also includes the following:

- **Channels**—Specifies the channel(s) for which you want to select the direction.
- Selected Channel(s) Settings—Specifies the default line direction for each channel.

sbRIO-9629

Single-Board Reconfigurable I/O (MIO and DIO), 16 AI channels, 4 AO channels, 4 5 V DIO channels, 2 RS-232 Serial ports, 1 RS-485 Serial port, 1 CAN port, RIO mezzanine card connector, Artix-7 200T FPGA

## Software Reference (?)

#### **FPGA Interface**

### sbRIO-9629 Pinouts

## Connector J2, MIO





## Connector J3, CAN Port



### Connectors J4 and J6, RS-232 Serial Ports



### Connector J5, RS-485 Serial Port



# **Related Topics**

Configuring a Project with Connected Hardware
Configuring a Project with Offline Hardware
RT Watchdog VIs

sbRIO-9629 (FPGA Interface)

Single-Board Reconfigurable I/O (MIO and DIO), 16 AI channels, 4 AO channels, 4 5 V DIO channels, 2 RS-232 Serial ports, 1 RS-485 Serial port, 1 CAN port, RIO mezzanine card connector, Artix-7 200T FPGA

## FPGA I/O Node

You can use an FPGA I/O Node, configured for reading and writing, with this device.

### **Terminals in Software**

Use the <u>FPGA I/O Node</u> to access the following terminals for this device.

| Terminal             | Description                                                                                                            |
|----------------------|------------------------------------------------------------------------------------------------------------------------|
| Conn0_AI/AI <b>x</b> | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. The sbRIO-9629 has AI channels 0 to 15.   |
| Conn0_AO/AOx         | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. The sbRIO-9629 has AO channels 0 to 3.   |
| Conn0_DIO0-3/DIOx    | Digital input/output channel <b>x</b> , where <b>x</b> is the channel number. The sbRIO-9629 has DIO channel s 0 to 3. |
| Conn0_DIO0-3/DIO3:0  | Digital port consisting of channels 0 through 3. Channel 3 signifies the MSB and channel 0 signifies the LSB.          |

### **Arbitration**

You cannot configure arbitration settings for analog input and analog output channels of this device. Analog input and analog output channels on this device only support the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration.

You can configure the arbitration settings for digital output channels on this device in the Advanced Code Generation page on the FPGA I/O Properties dialog box. The default arbitration setting is Never Arbitrate.

Digital input channels on this device only support the Never Arbitrate option for arbitration. You cannot configure arbitration settings for digital input channels on this device.

### I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method            | I/OType | Description                                                                                                                                                    |
|-------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data   | DIO     | Refer to the <u>FPGA I/O Method N</u> <u>ode</u> topic for a description of th is method.                                                                      |
| Set Output Enable | DIO     | Sets the line direction of the dig ital channel or the digital port. Refer to the <u>FPGA I/O Method N</u> <u>ode</u> topic for a description of th is method. |

## **Module Methods**

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method       | I/OType | Description                                                                                  |
|--------------|---------|----------------------------------------------------------------------------------------------|
| Check Status |         | Returns a Boolean value that in dicates whether the DIO modul e is ready for I/O operations. |

# **I/O Properties**

Use the <u>FPGA I/O Property Node</u> to access the following properties for this device.

| Property      | І/ОТуре | Description                                                                                                                                                                                                                                         |
|---------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Terminal Mode | AI      | Sets the terminal mode for a channel as RSE (referenced single-ended) or DIFF (differential). This property overwrites the value you configure in the <b>Module Properties</b> dialog box. You cannot configure channels 8 through 15 to DIFF mode. |
| Voltage Range | Al      | Sets the input range for a chann el as ±10 V, ±5 V, ±2 V, or ±1 V. Th is property overwrites the value you configure in the Module P roperties dialog box.                                                                                          |
| LSB Weight    | AO      | Returns the LSB weight in nV/LS<br>B for the channel. Use this valu<br>e to convert AO data if you set t                                                                                                                                            |

|        |    | he Calibration Mode to Raw in the Module Properties dialog box.                                                                                                       |
|--------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset | AO | Returns the calibration offset in nV for the channel. Use this val ue to convert AO data if you set the Calibration Mode to Raw in the Module Properties dial og box. |

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following properties for this device.

| Property                 | І/ОТуре | Description                                                                                                                                                                                |
|--------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight (±10 V range) | AI      | Returns the LSB weight in pV/LS B for the ±10 V range. Use this v alue to convert AI data if you se t the Calibration Mode to Raw in the Module Properties d ialog box.                    |
| LSB Weight (±5 V range)  | Al      | Returns the LSB weight in pV/LS B for the ±5 V range. Use this value to convert AI data if you set the Calibration Mode to Raw in the Module Properties dialog box.                        |
| LSB Weight (±2 V range)  | Al      | Returns the LSB weight in pV/LS B for the ±2 V range. Use this val ue to convert AI data if you set t he <b>Calibration Mode</b> to <b>Raw</b> in the <b>Module Properties</b> dialog box. |
| LSB Weight (±1 V range)  | AI      | Returns the LSB weight in pV/LS B for the ±1 V range. Use this value to convert AI data if you set the Calibration Mode to Raw in the Module Properties dialog box.                        |

| Offset (±10 V range) | Al | Returns the calibration offset in nV for the ±10 V range. Use this value to convert AI data if you s et the Calibration Mode to R aw in the Module Properties dialog box.  |
|----------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset (±5 V range)  | Al | Returns the calibration offset in nV for the ±5 V range. Use this v alue to convert AI data if you se t the Calibration Mode to Ra w in the Module Properties d ialog box. |
| Offset (±2 V range)  | Al | Returns the calibration offset in nV for the ±2 V range. Use this v alue to convert AI data if you se t the Calibration Mode to Ra w in the Module Properties d ialog box. |
| Offset (±1 V range)  | Al | Returns the calibration offset in nV for the ±1 V range. Use this v alue to convert AI data if you se t the Calibration Mode to Raw in the Module Properties d ialog box.  |

### Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u> for digital I/O only. Configure the number of output synchronizing registers or input synchronizing registers for the channels on this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box.

The Set Output Enable method node is not supported in the single-cycle Timed Loop. When writing to a DIO I/O node in a single-cycle Timed Loop, the I/O node will not change the DIO line directions. To set the line directions to output when writing to the DIO channels in a single-cycle Timed Loop, either configure the default line directions to output in the **Module Properties** dialog box, or use the Set Output Enable method node outside a single-cycle Timed Loop.

This device supports the Number of Synchronizing Registers for Output Data synchronizing register option when used in SCTL output. This option supports the same functionality as the Number of Synchronizing Registers for Output Data option described in the Advanced Code Generation FPGA I/O Properties Page (FPGA Module) topic, with the exception that you can use this option only in a single-cycle Timed Loop. You can implement either 0 or 1 synchronizing registers inside the single-cycle Timed Loop, however, if you configure 0 synchronizing registers outside of the single-cycle Timed Loop, the FPGA VI implements 1 synchronizing register by default.

When the device is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

sbRIO-9637

Single-Board Reconfigurable I/O (MIO and DIO), 16 AI channels, 4 AO channels, 28 3.3 V DIO channels, 2 RS-232 Serial ports, 1 RS-485 Serial port, 1 CAN port, Zynq-7020 FPGA

Software Reference (?)

FPGA Interface

# sbRIO-9637 Pinouts

### Connector J4, DIO



### Connector J5, MIO



| 1  | 2                                                                                                                                  | Al0                                                                                                                                                                                |
|----|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3  | 4                                                                                                                                  | GND                                                                                                                                                                                |
| 5  | 6                                                                                                                                  | Al1                                                                                                                                                                                |
| 7  | 8                                                                                                                                  | Al2                                                                                                                                                                                |
| 9  | 10                                                                                                                                 | GND                                                                                                                                                                                |
| 11 | 12                                                                                                                                 | Al13                                                                                                                                                                               |
| 13 | 14                                                                                                                                 | Al14                                                                                                                                                                               |
| 15 | 16                                                                                                                                 | GND                                                                                                                                                                                |
| 17 | 18                                                                                                                                 | Al5                                                                                                                                                                                |
| 19 | 20                                                                                                                                 | Al6                                                                                                                                                                                |
| 21 | 22                                                                                                                                 | GND                                                                                                                                                                                |
| 23 | 24                                                                                                                                 | Al7                                                                                                                                                                                |
| 25 | 26                                                                                                                                 | GND                                                                                                                                                                                |
| 27 | 28                                                                                                                                 | AO0                                                                                                                                                                                |
| 29 | 30                                                                                                                                 | AO1                                                                                                                                                                                |
| 31 | 32                                                                                                                                 | AO2                                                                                                                                                                                |
| 33 | 34                                                                                                                                 | AO3                                                                                                                                                                                |
| 35 | 36                                                                                                                                 | NC                                                                                                                                                                                 |
| 37 | 38                                                                                                                                 | NC                                                                                                                                                                                 |
| 39 | 40                                                                                                                                 | NC                                                                                                                                                                                 |
| 41 | 42                                                                                                                                 | NC                                                                                                                                                                                 |
| 43 | 44                                                                                                                                 | DIO0                                                                                                                                                                               |
| 45 | 46                                                                                                                                 | DIO1                                                                                                                                                                               |
| 47 | 48                                                                                                                                 | DIO2                                                                                                                                                                               |
| 49 | 50                                                                                                                                 | DIO3                                                                                                                                                                               |
|    | 3<br>5<br>7<br>9<br>11<br>13<br>15<br>17<br>19<br>21<br>23<br>25<br>27<br>29<br>31<br>33<br>35<br>37<br>39<br>41<br>43<br>45<br>47 | 3 4<br>5 6<br>7 8<br>9 10<br>11 12<br>13 14<br>15 16<br>17 18<br>19 20<br>21 22<br>23 24<br>25 26<br>27 28<br>30 34<br>35 36<br>37 38<br>39 40<br>41 42<br>43 44<br>45 46<br>47 48 |

GND

9 10

13 14

15 16

17 18

21 22

23 24

25 26

31 32

33 34

39 40

41 42

43 44

45 46

47 48

49 50

38

12

DIO4

DIO5

6 DIO6

DIO7

DIO8

DIO10

DIO11

DIO12

DIO13

DIO14

DIO15 DIO16

28 DIO17

DIO18

DIO19 DIO20

DIO21

DIO22

DIO23 DIO24

DIO25

DIO26

DIO27

5 V

### Connector W1, CAN Port



### Connectors W2 and W4, RS-232 Serial Ports



#### Connector W3, RS-485 Serial Port



## **Related Topics**

Configuring a Project with Connected Hardware
Configuring a Project with Offline Hardware
RT Watchdog VIs

sbRIO-9637 (FPGA Interface)

Single-Board Reconfigurable I/O (MIO and DIO)

16 AI channels, 4 AO channels, 28 3.3 V DIO channels, 2 RS-232 Serial ports, 1 RS-485 Serial port, 1 CAN port, Zyng-7020 FPGA

### FPGA I/O Node

You can use an FPGA I/O Node, configured for reading and writing, with this device.

### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal               | Description                                                                                                          |
|------------------------|----------------------------------------------------------------------------------------------------------------------|
| Connector0/Al <b>x</b> | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. The sbRIO-9637 has AI channels 0 to 15. |

| Connector0/AOx                   | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. The sbRIO-9637 has AO channels 0 to 3.                                                                                                                                                              |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Connector <b>x</b> /DIO <b>y</b> | Digital input/output channel <b>y</b> on connector <b>x</b> , where <b>y</b> is the channel number and <b>x</b> is the con nector number. The sbRIO-9637 has channels 0 t o 27. Use the FPGA I/O Node or the Set Output D ata or Set Output Enable method to access this channel. |

#### **Arbitration**

You can configure the arbitration settings for the DIO channels of this device in the Advanced Code Generation page of the FPGA I/O Properties dialog box. The default arbitration setting is Never Arbitrate.

### I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method            | Description                                                                       |
|-------------------|-----------------------------------------------------------------------------------|
| ·                 | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |
| Set Output Enable | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |

### **Module Methods**

This device does not support any module methods.

### **Properties**

Use the FPGA I/O Property Node to access the following properties for this device.

| Property      | Description                                                                                                                                                                            |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Terminal Mode | Sets the terminal mode for a channel as RSE (ref erenced single-ended) or DIFF (differential). This property overwrites the value you configure in the FPGA I/O Properties dialog box. |

| Voltage Range | Sets the input range for a channel as ±10 V, ±5 V, ±2 V, or ±1 V. This property overwrites the value |
|---------------|------------------------------------------------------------------------------------------------------|
|               | you configure in the <b>FPGA I/O Properties</b> dial og box.                                         |

### Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u> for digital I/O only. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box.

sbRIO-9638

Single-Board Reconfigurable I/O (MIO), 16 AI channels, 4 AO channels, 28 5 V DIO channels, 2 RS-232 Serial ports, 1 RS-485 Serial port, 1 CAN port, Artix-7 100T FPGA

#### Software Reference (?)

FPGA Interface

# sbRIO-9638 Pinouts Connector J1, DIO





### Connector J2, MIO





### Connector J3, CAN Port



### Connectors J4 and J6, RS-232 Serial Ports



### Connector J5, RS-485 Serial Port



### **Related Topics**

Configuring a Project with Connected Hardware Configuring a Project with Offline Hardware **RT Watchdog VIs** 

sbRIO-9638 (FPGA Interface)

Single-Board Reconfigurable I/O (MIO), 16 AI channels, 4 AO channels, 28 5 V DIO channels, 2 RS-232 Serial ports, 1 RS-485 Serial port, 1 CAN port, Artix-7 100T FPGA

### FPGA I/O Node

You can use an FPGA I/O Node, configured for <u>reading</u> and <u>writing</u>, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal             | Description                                                                                                                                                                                                                                                                                 |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conn0_AI/AI <b>x</b> | Analog input channel <b>x</b> , where <b>x</b> is the number of the channel. The sbRIO-9638 has AI channels 0 to 15.                                                                                                                                                                        |
| Conn0_AO/AOx         | Analog output channel <b>x</b> , where <b>x</b> is the number of the channel. The sbRIO-9638 has AO channels 0 to 3.                                                                                                                                                                        |
| Connw_DIOx-y/DIOz    | Digital input/output channel <b>z</b> on connector <b>w</b> , where <b>z</b> is the channel number, <b>w</b> is the connect or number, and <b>x</b> and <b>y</b> specify the module that contains the channel. The sbRIO-9638 has DIO c hannels 0 to 27 organized into 4 separate modul es. |
| Connw_DIOx-y/DIOy:x  | Digital port consisting of channels <b>x</b> and <b>y</b> on connector <b>w</b> . Channel <b>y</b> signifies the MSB and channel <b>x</b> signifies the LSB.                                                                                                                                |

#### **Arbitration**

You cannot configure arbitration settings for analog input and analog output channels of this device. Analog input and analog output channels on this device only support the <u>Arbitrate if Multiple Requestors Only</u> option for arbitration.

You can configure the arbitration settings for digital output channels on this device in the <u>Advanced Code Generation</u> page on the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

Digital input channels on this device only support the <u>Never Arbitrate</u> option for arbitration. You cannot configure arbitration settings for digital input channels on this device.

### I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for this device.

| Method            | І/ОТуре | Description                                                                                                                                                    |
|-------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data   | DIO     | Refer to the <u>FPGA I/O Method N</u> <u>ode</u> topic for a description of th is method.                                                                      |
| Set Output Enable | DIO     | Sets the line direction of the dig ital channel or the digital port. Refer to the <u>FPGA I/O Method N</u> <u>ode</u> topic for a description of th is method. |

#### **Module Methods**

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method       | I/OType | Description                                                                                  |
|--------------|---------|----------------------------------------------------------------------------------------------|
| Check Status |         | Returns a Boolean value that in dicates whether the DIO modul e is ready for I/O operations. |

### I/O Properties

Use the <u>FPGA I/O Property Node</u> to access the following properties for this device.

| Property      | І/ОТуре | Description                                                                                                                                                                                                                                          |
|---------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Terminal Mode | Al      | Sets the terminal mode for a channel as RSE (referenced single-ended) or DIFF (differential). This property overwrites the value you configure in the <b>Module Properties</b> dialog box. You can not configure channels 8 through 15 to DIFF mode. |
| Voltage Range | AI      | Sets the input range for a chann el as ±10 V, ±5 V, ±2 V, or ±1 V. Th is property overwrites the value you configure in the <b>Module P roperties</b> dialog box.                                                                                    |
| LSB Weight    | AO      | Returns the LSB weight in nV/LS B for the channel. Use this value to convert AO data if you set the Calibration Mode to Raw in the Module Properties dialog box.                                                                                     |
| Offset        | AO      | Returns the calibration offset in nV for the channel. Use this val ue to <u>convert AO data</u> if you set the <b>Calibration Mode</b> to <b>Raw</b> in the <b>Module Properties</b> dial og box.                                                    |

# **Module Properties**

Use the <u>FPGA I/O Property Node</u> to access the following properties for this device.

| Property                 | І/ОТуре | Description                                                                                                                                                             |
|--------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight (±10 V range) | AI      | Returns the LSB weight in pV/LS B for the ±10 V range. Use this v alue to convert AI data if you se t the Calibration Mode to Raw in the Module Properties d ialog box. |

| LSB Weight (±5 V range) | AI | Returns the LSB weight in pV/LS B for the ±5 V range. Use this value to convert AI data if you set the Calibration Mode to Raw in the Module Properties dialog box.        |
|-------------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSB Weight (±2 V range) | AI | Returns the LSB weight in pV/LS B for the ±2 V range. Use this val ue to convert AI data if you set t he Calibration Mode to Raw in the Module Properties dialog box.      |
| LSB Weight (±1 V range) | Al | Returns the LSB weight in pV/LS B for the ±1 V range. Use this value to convert AI data if you set the Calibration Mode to Raw in the Module Properties dialog box.        |
| Offset (±10 V range)    | Al | Returns the calibration offset in nV for the ±10 V range. Use this value to convert AI data if you s et the Calibration Mode to R aw in the Module Properties dialog box.  |
| Offset (±5 V range)     | AI | Returns the calibration offset in nV for the ±5 V range. Use this v alue to convert AI data if you se t the Calibration Mode to Ra w in the Module Properties d ialog box. |
| Offset (±2 V range)     | Al | Returns the calibration offset in nV for the ±2 V range. Use this v alue to convert AI data if you se t the Calibration Mode to Raw in the Module Properties d ialog box.  |
| Offset (±1 V range)     | Al | Returns the calibration offset in nV for the ±1 V range. Use this v alue to <u>convert AI data</u> if you se                                                               |

|  | t the Calibration Mode to Ra<br>w in the Module Properties d<br>ialog box. |
|--|----------------------------------------------------------------------------|
|--|----------------------------------------------------------------------------|

### Single-Cycle Timed Loop

This device supports the single-cycle Timed Loop for digital I/O only. Configure the number of output synchronizing registers or input synchronizing registers for the channels on this device in the Advanced Code Generation page of the FPGA I/O Properties dialog box.

The Set Output Enable method node is not supported in the single-cycle Timed Loop. When writing to a DIO I/O node in a single-cycle Timed Loop, the I/O node will not change the DIO line directions. To set the line directions to output when writing to the DIO channels in a single-cycle Timed Loop, either configure the default line directions to output in the Module Properties dialog box, or use the Set Output Enable method node outside a single-cycle Timed Loop.

This device supports the Number of Synchronizing Registers for Output Data synchronizing register option when used in SCTL output. This option supports the same functionality as the Number of Synchronizing Registers for Output Data option described in the Advanced Code Generation FPGA I/O Properties Page (FPGA Module) topic, with the exception that you can use this option only in a single-cycle Timed Loop. You can implement either 0 or 1 synchronizing registers inside the single-cycle Timed Loop, however, if you configure 0 synchronizing registers outside of the single-cycle Timed Loop, the FPGA VI implements 1 synchronizing register by default.

When the device is within a single-cycle Timed Loop, it must be ready to perform digital I/O before a loop containing digital I/O starts. Poll the **Ready** output of the Check Status method to determine whether the module is ready. Digital input operations return invalid data if the module is not ready. The module also might ignore or delay digital output operations if it is not ready.

Converting Analog Input Values for the sbRIO-9628/9629/9638 (FPGA Interface)

Set the **Calibration Mode** to **Calibrated** in the **Module Properties** dialog box for the onboard analog input module if you want the <u>FPGA I/O Node</u> to return calibrated, <u>fixed-point</u> data for the module. If you set the **Calibration Mode** to **Raw**, the FPGA I/O Node returns uncalibrated, binary values. These binary values can be converted to calibrated volts by applying the calibration constants. The conversion of binary data to calibrated data can be done in the host VI.

Using an Equation to Convert and Calibrate Values

You can use the following equation in the host VI to convert binary analog input values to calibrated volts:

**Volts** = (**Binary Value** × **LSB Weight** - **Offset**) where

**Binary Value** is the signed value returned by the FPGA I/O Node **LSB Weight** is the value returned by the LSB Weight property **Offset** is the value returned by the Offset property.

The **LSB Weight** property is returned in units of pV/LSB. The **Offset** property is returned in units of nV.

To convert to calibrated volts, use the FPGA I/O Property Node to read the LSB Weight and Offset properties for the desired input range. If you do not want to read the LSB Weight and Offset values from the module, you can convert to uncalibrated engineering units by using the following typical values for **Offset** and **LSB Weight**:

Offset = 0 V

The typical **LSB Weight** depends on the input range. See the table below:

| Input Range | Typical LSB Weight |
|-------------|--------------------|
| ±10 V       | 320 μV/LSB         |
| ±5 V        | 160 μV/LSB         |
| ±2 V        | 64 μV/LSB          |
| ±1 V        | 32 μV/LSB          |

Converting Analog Output Values for the sbRIO-9628/9629/9638 (FPGA Interface)

Set the Calibration Mode to Calibrated in the Module Properties dialog box for the onboard analog output module if you want the FPGA I/O Node to accept fixed-point data in units of volts for the module. If you set the **Calibration Mode** to Raw, the FPGA I/O Node accepts only binary values. You must convert output voltage values to binary values using the calibration constants before you write them to the FPGA I/O node. The conversion of voltage values to binary values can be done in the host VI.

Using an Equation to Convert Voltage to Binary

You can use the following equation in the host VI to convert the analog output values to binary values:

Binary Value = (Voltage Value - Offset) ÷ LSB Weight where

> **Binary Value** is the value you write to the FPGA I/O Node **Voltage Value** is the voltage in V that you want the channel to output **Offset** is the value returned by the Offset property **LSB Weight** is the value returned by the LSB Weight property.

The **LSB Weight** property is returned in units of nV/LSB. The **Offset** property is returned in units of nV.

NI recommends using calibrated values for analog output. To convert calibrated voltage values, use the <u>FPGA I/O Property Node</u> to read the LSB Weight and Offset properties. If you do not want to read the LSB Weight and Offset values from the module, you can convert uncalibrated voltage values by using the following typical values for **Offset** and **LSB Weight**:

Offset = 0 V LSB Weight = 320  $\mu$ V/LSB

Module Properties Dialog Box for the sbRIO-9628/9629/9638 (FPGA Interface)

Right-click an onboard I/O module in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure an onboard I/O module.

For all onboard I/O modules, this dialog box includes the following components:

- Name—Specifies the name of the onboard I/O module, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the module based on the connector number and channel numbers. You can use this field to give the onboard module a descriptive name.
- Module Type—Specifies the type of module. You cannot change this option.
- Location—Specifies the connector containing the onboard module's channels. You cannot change this option.

The onboard AI module's dialog box also includes the following:

Calibration Mode—Sets the calibration mode for the onboard module.
 Select Calibrated if you want the <u>FPGA I/O Node</u> to return calibrated, fixed-point data for the module in units of volts. The <u>fixed-point</u> data is signed, with

a word length of 24 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to return uncalibrated, binary data for the module. If you select Raw, you must convert and calibrate the analog input values in the host VI. The default is **Calibrated**.

- Channel Configuration—Specifies the input range for each channel.
  - Channels—Specifies the channel(s) for which you want to select the input range.
  - Input Range—Specifies the input range for the selected channel(s) as  $\pm 10 \text{ V}, \pm 5 \text{ V}, \pm 2 \text{ V}, \text{ or } \pm 1 \text{ V}.$
  - Terminal Mode—Specifies the terminal mode for the selected channel(s) as RSE (referenced single-ended) or DIFF (differential).
- Minimum Time Between Conversions—Specifies the minimum time between conversions in us. This time determines the shortest possible time between any two conversions. For channels sampled within the same FPGA I/O Node, the time you set determines the exact time between conversions. For channels sampled within separate FPGA I/O Nodes or for conversions caused by looping on an FPGA I/O Node, the time you set may be less than the actual time between conversions. However, the minimum time you set is never greater than the time between conversions. If the application tries to execute an FPGA I/O Node faster than the specified minimum time between conversions, the conversion is delayed until the minimum time you set is satisfied. The default minimum time between conversions is 8 us. The accuracy specifications in the sbRIO-9638 hardware documentation on ni.com/manuals are based on this default value. If you set the minimum time between conversions to at least 8 µs, the accuracy of the module is not affected. If you set the minimum time between conversions to less than 8 µs, the accuracy of the onboard module degrades if you sample data from multiple channels.

The onboard AO module's dialog box also includes the following:

 Calibration Mode—Sets the calibration mode for the onboard module. Select Calibrated if you want the FPGA I/O Node to accept fixed-point data in units of volts when writing to the module. The fixed-point data is signed, with

a word length of 20 bits and an integer word length of 5 bits. Select **Raw** if you want the FPGA I/O Node to accept calibrated, binary data when writing to the module. If you select **Raw**, you must convert the analog output values in the host VI before you write them to the module. The default is **Calibrated**.

The onboard DIO module's dialog box also includes the following:

- **Channels**—Specifies the channel(s) for which you want to select the direction.
- Selected Channel(s) Settings—Specifies the default line direction for each channel.

sbRIO-9651 SOM

Embedded System on Module (SOM) with Real-Time Processor and Reconfigurable FPGA, 160 configurable DIO channels, 85,000 logic cells

#### **Software Reference (?)**

**<u> Getting Started with the sbRIO-9651 SOM in LabVIEW</u>** 

#### Hardware Documentation (?)

sbRIO-9651 SOM hardware documentation on ni.com/manuals

# sbRIO-9651 Pin Assignments

#### J1 Connector



Legend

USB & Ethernet BANK0 (LVTTL)/DIO 0-15 Power In

LED Signals (LVTTL) BANK1/DIO 16-39 Ground

SDIO Interface BANK2/DIO 40-63

Support Signals (LVTTL) BANK3/DIO 64-87

| 313<br>GND      | 314<br>DIO_69   | 315<br>GND      | 316<br>DIO_75   | 317<br>GND      | 318<br>DIO_81   | 319<br>GND             | 320<br>DIO_87_SR<br>CC |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|------------------------|------------------------|
| 305<br>DIO_66_N | 306<br>DIO_69_N | 307<br>DIO_72_N | 308<br>DIO_75_N | 309<br>DIO_78_N | 310<br>DIO_81_N | 311<br>DIO_84_N        | 312<br>DIO_87_N        |
| 297<br>DIO_66   | 298<br>GND      | 299<br>DIO_72   | 300<br>GND      | 301<br>DIO_78   | 302<br>GND      | 303<br>DIO_84_SR<br>CC | 304<br>GND             |
| 289<br>GND      | 290<br>DIO_68   | 291<br>GND      | 292<br>DIO_74   | 293<br>GND      | 294<br>DIO_80   | 295<br>GND             | 296<br>DIO_86_M<br>RCC |
| 281<br>DIO_65_N | 282<br>DIO_68_N | 283<br>DIO_71_N | 284<br>DIO_74_N | 285<br>DIO_77_N | 286<br>DIO_80_N | 287<br>DIO_83_N        | 288<br>DIO_86_N        |
| 273<br>DIO_65   | 274<br>GND      | 275<br>DIO_71   | 276<br>GND      | 277<br>DIO_77   | 278<br>GND      | 279<br>DIO_83          | 280<br>GND             |
| 265<br>GND      | 266<br>DIO_67   | 267<br>GND      | 268<br>DIO_73   | 269<br>GND      | 270<br>DIO_79   | 271<br>GND             | 272<br>DIO_85_M<br>RCC |
| 257<br>DIO_64_N | 258<br>DIO_67_N | 259<br>DIO_70_N | 260<br>DIO_73_N | 261<br>DIO_76_N | 262<br>DIO_79_N | 263<br>DIO_82_N        | 264<br>DIO_85_N        |
| 249<br>DIO_64   | 250<br>GND      | 251<br>DIO_70   | 252<br>GND      | 253<br>DIO_76   | 254<br>GND      | 255<br>DIO_82          | 256<br>GND             |
| 241<br>GND      | 242<br>DIO_46   | 243<br>GND      | 244<br>DIO_52   | 245<br>GND      | 246<br>DIO_58   | 247<br>GND             | 248<br>VIO_BANK<br>3   |
| 233<br>DIO_42_N | 234<br>DIO_46_N | 235<br>DIO_49_N | 236<br>DIO_52_N | 237<br>DIO_55_N | 238<br>DIO_58_N | 239<br>DIO_61_N        | 240<br>VIO_BANK<br>3   |
| 225<br>DIO_52   | 226<br>GND      | 227<br>DIO_49   | 228<br>GND      | 229<br>DIO_55   | 230<br>GND      | 231<br>DIO_61_M<br>RCC | 232<br>GND             |
| 217<br>GND      | 218<br>DIO_45   | 219<br>GND      | 220<br>DIO_51   | 221<br>GND      | 222<br>DIO_57   | 223<br>GND             | 224<br>DIO_63_SR<br>CC |
| 209<br>DIO_41_N | 210<br>DIO_45_N | 211<br>DIO_48_N | 212<br>DIO_51_N | 213<br>DIO_54_N | 214<br>DIO_57_N | 215<br>DIO_60_N        | 216<br>DIO_63_N        |

| 201<br>DIO_41   | 202<br>GND      | 203<br>DIO_48   | 204<br>GND      | 205<br>DIO_54   | 206<br>GND             | 207<br>DIO_60_SR<br>CC | 208<br>GND             |
|-----------------|-----------------|-----------------|-----------------|-----------------|------------------------|------------------------|------------------------|
| 193<br>GND      | 194<br>DIO_44   | 195<br>GND      | 196<br>DIO_50   | 197<br>GND      | 198<br>DIO_56          | 199<br>GND             | 200<br>DIO_62_M<br>RCC |
| 185<br>DIO_40_N | 186<br>DIO_44_N | 187<br>DIO_47_N | 188<br>DIO_50_N | 189<br>DIO_53_N | 190<br>DIO_56_N        | 191<br>DIO_59_N        | 192<br>DIO_62_N        |
| 177<br>DIO_40   | 178<br>GND      | 179<br>DIO_47   | 180<br>GND      | 181<br>DIO_53   | 182<br>GND             | 183<br>DIO_59          | 184<br>GND             |
| 169<br>GND      | 170<br>DIO_43   | 171<br>GND      | 172<br>DIO_28   | 173<br>GND      | 174<br>DIO_35_P<br>UDC | 175<br>GND             | 176<br>VIO_BANK<br>2   |
| 161<br>DIO_18_N | 162<br>DIO_43_N | 163<br>DIO_24_N | 164<br>DIO_28_N | 165<br>DIO_31_N | 166<br>DIO_35_N        | 167<br>DIO_38_N        | 168<br>VIO_BANK<br>2   |
| 153<br>DIO_18   | 154<br>GND      | 155<br>DIO_24   | 156<br>GND      | 157<br>DIO_31   | 158<br>GND             | 159<br>DIO_38_M<br>RCC | 160<br>GND             |
| 145<br>GND      | 146<br>DIO_21   | 147<br>GND      | 148<br>DIO_27   | 149<br>GND      | 150<br>DIO_34          | 151<br>GND             | 152<br>DIO_39_SR<br>CC |
| 137<br>DIO_17_N | 138<br>DIO_21_N | 139<br>DIO_23_N | 140<br>DIO_27_N | 141<br>DIO_30_N | 142<br>DIO_34_N        | 143<br>DIO_37_N        | 144<br>DIO_39_N        |
| 129<br>DIO_17   | 130<br>GND      | 131<br>DIO_23   | 132<br>GND      | 133<br>DIO_30   | 134<br>GND             | 135<br>DIO_37_M<br>RCC | 136<br>GND             |
| 121<br>GND      | 122<br>DIO_20   | 123<br>GND      | 124<br>DIO_26   | 125<br>GND      | 126<br>DIO_33          | 127<br>GND             | 128<br>VIO_BANK<br>1   |
| 113<br>DIO_16_N | 114<br>DIO_20_N | 115<br>DIO_22_N | 116<br>DIO_26_N | 117<br>DIO_29_N | 118<br>DIO_33_N        | 119<br>DIO_36_N        | 120<br>VIO_BANK<br>1   |
| 105<br>DIO_16   | 106<br>GND      | 107<br>DIO_22   | 108<br>GND      | 109<br>DIO_29   | 110<br>GND             | 111<br>DIO_36_SR<br>CC | 112<br>GND             |
| 97<br>GND       | 98<br>DIO_19    | 99<br>GND       | 100<br>DIO_25   | 101<br>GND      | 102<br>DIO_32          | 103<br>GND             | 104<br>VCC_3V3         |

| 89<br>GND            | 90<br>DIO_19_N        | 91<br>GND             | 92<br>DIO_25_N        | 93<br>GND                 | 94<br>DIO_32_N         | 95<br>GND             | 96<br>VCC_3V3         |
|----------------------|-----------------------|-----------------------|-----------------------|---------------------------|------------------------|-----------------------|-----------------------|
| 81<br>USB0_VBU<br>S  | 82<br>GND             | 83<br>DIO_4           | 84<br>GND             | 85<br>DIO_8               | 86<br>GND              | 87<br>DIO_15_M<br>RCC | 88<br>VCC_3V3         |
| 73<br>USB0_CPE<br>N  | 74<br>DIO_1           | 75<br>DIO_3           | 76<br>DIO_6           | 77<br>GND                 | 78<br>DIO_12           | 79<br>DIO_14          | 80<br>VCC_3V3         |
| 65<br>USB0_MO<br>DE  | 66<br>DIO_0           | 67<br>GND             | 68<br>DIO_5           | 69<br>DIO_7               | 70<br>DIO_11           | 71<br>GND             | 72<br>GND             |
| 57<br>GND            | 58<br>USB1_VBU<br>S   | 59<br>DIO_2           | 60<br>Serial1_RX      | 61<br>GND                 | 62<br>DIO_10           | 63<br>DIO_13          | 64<br>VBAT            |
| 49<br>GND            | 50<br>USB1_CPE<br>N   | 51<br>GND             | 52<br>Serial1_TX      | 53<br>FPGA_CFG            | 54<br>DIO_9            | 55<br>GND             | 56<br>RESERVED-<br>NC |
| 41<br>USB0_DN        | 42<br>GND             | 43<br>USB1_DN         | 44<br>GND             | 45<br>GND                 | 46<br>TEMP_ALE<br>RT   | 47<br>SYS_RST#        | 48<br>GND             |
| 33<br>USB0_DP        | 34<br>GND             | 35<br>USB1_DP         | 36<br>GND             | 37<br>CARRIER_R<br>ST#    | 38<br>SD_PWR_E<br>N    | 39<br>GND             | 40<br>SD_WP           |
| 25<br>GND            | 26<br>GBE0_MDI<br>1_N | 27<br>GND             | 28<br>GBE0_MDI<br>3_N | 29<br>GND                 | 30<br>SD_D3            | 31<br>SD_CMD          | 32<br>SD_CD#          |
| 17<br>GND            | 18<br>GBE0_MDI<br>1_P | 19<br>GND             | 20<br>GBE0_MDI<br>3_P | 21<br>GND                 | 22<br>SD_D1            | 23<br>GND             | 24<br>SD_D2           |
| 9<br>GBE0_MDI<br>0_N | 10<br>GND             | 11<br>GBE0_MDI<br>2_N | 12<br>GND             | 13<br>GBE0_SPE<br>ED_LEDy | 14<br>STATUS_LE<br>D   | 15<br>SD_CLK          | 16<br>GND             |
| 1<br>GBE0_MDI<br>0_P | 2<br>GND              | 3<br>GBE0_MDI<br>2_P  | 4<br>GND              | 5<br>GBE0_SPE<br>ED_LEDg  | 6<br>GBE0_ACT<br>_LEDg | 7<br>GND              | 8<br>SD_D0            |

### **Related Topics**

Configuring a Project with Connected Hardware Configuring a Project with Offline Hardware RT Watchdog VIs

Getting Started with the sbRIO-9651 in LabVIEW

The sbRIO-9651 System on Module (SOM) requires a mated carrier board in order to function as a complete LabVIEW FPGA and LabVIEW Real-Time target. The sbRIO-9651 reserves some pins on its connector for specific functionality, such as primary Ethernet and USB ports, but provides several banks of additional pins that you can configure for purposes specific to your application.

The sbRIO-9651 SOM Development Kit includes a reference carrier board, which shows an example of how to implement additional I/O functionality you might require, such as Serial, CAN, and secondary Ethernet.

To use the sbRIO-9651 as a LabVIEW FPGA and LabVIEW Real-Time target in a LabVIEW project, you must first create a socketed component-level IP (CLIP) that defines the I/O configuration to use in your application.

Use this tutorial to create a CLIP for the sbRIO-9651 and add it to a LabVIEW project. Before You Begin

- Before you write any software, use the sbRIO-9651 System on Module Carrier Board Design Guide on ni.com/manuals to plan the layout of your carrier board and define the purpose of each pin on the connector. When you create a CLIP for the sbRIO-9651, you must already know the following details:
  - Which processor peripherals you want to enable
  - What pins you want to use
  - What I/O standards and drive strength you want to use for the pins
  - What I/O voltage level you require
  - What LabVIEW FPGA I/O Nodes your application will require
  - What timing constraints or clock resources you require

| Get started: ▶                                                  |
|-----------------------------------------------------------------|
| <u>Creating Component-Level IP</u><br><u>for the sbRIO-9651</u> |

#### Related Topics

<u>Using VHDL Code as Component-Level IP (FPGA Module)</u>

Creating Component-Level IP for the sbRIO-9651

Use the sbRIO CLIP Generator to generate a unique socketed CLIP that you can import into a LabVIEW project. The sbRIO CLIP Generator completes the following tasks for you:

- Generates processor peripherals
- Configures the raw FPGA I/O pins
- Generates a LabVIEW FPGA I/O Node interface for the socketed CLIP

Complete the following steps to launch the sbRIO CLIP Generator and create a new CLIP.

- Create a new LabVIEW project.
- 2. <u>Add an FPGA target to the project</u>. In the <u>Add Targets and Devices</u> dialog box, select **Real-Time Single-Board RIO**»sbRIO-9651.
- In the Project Explorer window, right-click the Chassis (sbRIO-9651) item and select New»FPGA Target.
- 4. Right-click the **FPGA Target** item and select **Launch sbRIO CLIP Generator**.



**Note** You can also launch the sbRIO CLIP Generator outside of LabVIEW in the following ways:

 (Windows 8.x) Click the NI Launcher tile on the Start screen and select CompactRIO»Single-Board RIO»sbRIO CLIP Generator

(Windows 7 or earlier) Select Start»All Programs»NI»CompactRIO»Single-Board RIO»sbRIO CLIP Generator . .

5. Step through the pages of the sbRIO CLIP Generator to name the CLIP, configure the peripherals you want to enable, create a LabVIEW FPGA I/O Node interface for the CLIP, and configure clock resources for the CLIP.



**Tip** Click **Help** in the sbRIO CLIP Generator or browse to the <NI>\CompactRIO\sb RIO\CLIP Generator directory to launch the NI Single-Board RIO CLIP **Generator Help**, which contains more information about using the sbRIO CLIP Generator.



**Note** If you want to make changes to an existing CLIP after it has been created, you must manually edit the generated CLIP files. You cannot use the sbRIO CLIP Generator to edit an existing CLIP. However, you can load the configuration for a previously saved CLIP so you can use it as the basis for a new CLIP.

| ◀ Review:                                      | Continue: >                                           |
|------------------------------------------------|-------------------------------------------------------|
| Getting Started with the sbRIO-9651 in LabVIEW | Adding a CLIP for the sbRIO-9651 to a LabVIEW Project |

**Related Topics** 

Using VHDL Code as Component-Level IP (FPGA Module)

Adding a CLIP for a Single-Board RIO Device to a LabVIEW Project

Complete the following steps to add the CLIP you created using the sbRIO CLIP Generator for a Single-Board RIO target to a LabVIEW project.

Before You Begin

- Use the sbRIO CLIP Generator to generate a unique socketed CLIP.
- 1. Create a new project.
- 2. Add an FPGA target to the project. In the Add Targets and Devices dialog box, select **Real-Time Single-Board RIO** and then select your device.
- 3. In the Project Explorer window, right-click the **Chassis** item and select **New»FPGA Target**.
- 4. Right-click the RMC Socket or sbRIO-9651 Socket item and select Properties to launch the Component-Level IP Properties or RMC Socket Properties dialog box.
- 5. On the <u>General</u> page, use the **RMC or sbRIO-9651 Socketed Component Level IP Declaration** drop-down list to select the CLIP you created.
- 6. On the <u>Clock Selections</u> page, configure any clocks that you specified on the Clock Settings page of the sbRIO CLIP Generator.
- 7. Click **OK** to close the Component-Level IP Properties dialog box.

| ◀ Review:                                      | Continue: >                              |
|------------------------------------------------|------------------------------------------|
| Creating Component-Level IP for the sbRIO-9651 | Implementing FPGA VIs for the sbRIO-9651 |

Related Topics

Creating FPGA VIs (FPGA Module)

Compiling, Downloading, and Running FPGA VIs (FPGA Module)

General Page (sbRIO-9651 Socket Properties Dialog Box)

In the <u>Component-Level IP Properties</u> dialog box for the <u>sbRIO-9651</u>, select **General** from the **Category** list to display this page, which you can use to select a <u>socketed</u> CLIP you created for the sbRIO-9651.

This page includes the following options:

• sbRIO-9651 Socketed Component Level IP Declaration—The socketed CLIP to add to the LabVIEW project. The drop-down list includes all

CLIP declarations saved in the following directories, or you can browse for a CLIP declaration saved in a different location:

- Documents\LabVIEW Data\CompactRIO\CLIPs\sbRIO-9651 —The directory in which the sbRIO CLIP Generator saves created CLIPs.
- <NI>\Shared\CompactRIO\CLIPs—The directory in which CLIPs may be distributed by an installer.





Note Leave < Select CLIP Declarat ion > selected if you do not want the socket to use a CLIP. All I/O on the sbRIO-9651 connector will be unused.

**Note** If the selected CLIP declaration is invalid, you cannot navigate to other pages of or click the **OK** button in the Component-Level IP Properties dialog box. Cancel the Component-Level IP Properties dialog box and correct any errors in the CLIP declaration before you try selecting the CLIP declaration in the Component-Level IP Properties dialog box again.

• **Description**—The description you provided in the sbRIO CLIP Generator for the selected CLIP declaration.

#### **Related Topics**

### Getting Started with the sbRIO-9651 in LabVIEW

Implementing FPGA VIs for the sbRIO-9651

Complete the following steps to implement a LabVIEW FPGA VI for the sbRIO-9651.

#### Before You Begin

- Use the sbRIO CLIP Generator to generate a unique socketed CLIP.
- Add the CLIP to a LabVIEW project.
- Connect the sbRIO-9651 to your computer with a USB cable or through a network.

- Configure the sbRIO-9651 with Measurement & Automation Explorer (MAX).
- 1. Create and compile your FPGA VI.
- 2. If you enabled any peripherals in your CLIP, such as secondary ethernet, CAN, or serial, <u>download your FPGA VI to the flash</u> of the sbRIO-9651 to load on boot in order to ensure that the driver for the peripheral can load properly at boot time.

You should now be able to run and deploy the system just like any other sbRIO device.

| ◀ Review:                                     |  |
|-----------------------------------------------|--|
| Adding a CLIP for the sbRIO-9651 to a LabVIEW |  |
| <u>Project</u>                                |  |

**Related Topics** 

**Creating FPGA VIs (FPGA Module)** 

Compiling, Downloading, and Running FPGA VIs (FPGA Module)

sbRIO-9683

RIO Mezzanine Card, General Purpose Inverter Controller

### Software Reference (?)

**FPGA Interface** 

### Hardware Documentation (?)

sbRIO-9683 hardware documentation on ni.com/manuals



**Note** Use the sbRIO-9683 with only sbRIO-9605/9606/9607 devices.

#### sbRIO-9683 Pinout



sbRIO-9683 (FPGA Interface)

**RIO Mezzanine Card** 

General Purpose Inverter Controller

### FPGA I/O Node

You can use an FPGA I/O Node, configured for reading and writing, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal                | Description                                                                                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AOx                     | Analog output channel where <b>x</b> is the number of the channel. The sbRIO-9683 has AO channels 0 to 7 that you can <u>add to a project</u> .                            |
| Half-Bridge DO <b>x</b> | Half-bridge digital output channel where <b>x</b> is th e number of the channel. The sbRIO-9683 has H alf-bridge DO channels 0 to 13 that you can <u>add</u> to a project. |
| Half-Bridge DO13:0      | Digital port consisting of Half-bridge DO channe ls 0 through 13. Channel 13 is returned in the MS B, and channel 0 is returned in the LSB.                                |
| Half-Bridge DO7:0       | Digital port consisting of Half-bridge DO channe ls 0 through 7. Channel 7 is returned in the MSB, and channel 0 is returned in the LSB.                                   |
| Half-Bridge DO13:8      | Digital port consisting of Half-bridge DO channe ls 8 through 13. Channel 13 is returned in the MS B, and channel 8 is returned in the LSB.                                |
| LVTTL DIOx              | LVTTL digital input/output channel where <b>x</b> is the number of the channel. The sbRIO-9683 has LV TTL DIO channels 0 to 31 that you can <u>add to a project</u> .      |
| LVTTL DIO7:0            | Digital port consisting of LVTTL DIO channels 0 t hrough 7. Channel 7 is returned in the MSB, and channel 0 is returned in the LSB.                                        |

| LVTTL DIO15:8             | Digital port consisting of LVTTL DIO channels 8 t hrough 15. Channel 15 is returned in the MSB, a nd channel 8 is returned in the LSB.                                        |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LVTTL DIO23:16            | Digital port consisting of LVTTL DIO channels 16 through 23. Channel 23 is returned in the MSB, a nd channel 16 is returned in the LSB.                                       |
| LVTTL DIO31:24            | Digital port consisting of LVTTL DIO channels 24 through 31. Channel 31 is returned in the MSB, a nd channel 24 is returned in the LSB.                                       |
| Relay Control DO <b>x</b> | Relay control digital output channel where <b>x</b> is t he number of the channel. The sbRIO-9683 has r elay control DO channels 0 to 3 that you can <u>add</u> to a project. |
| Relay Control DO3:0       | Digital port consisting of relay control DO channels 0 through 3. Channel 3 is returned in the MS B, and channel 0 is returned in the LSB.                                    |
| Scanned Al <b>x</b>       | Scanned analog input channel where <b>x</b> is the number of the channel. The sbRIO-9683 has scanned AI channels 0 to 7 that you can <u>add to a project</u> .                |
| Simultaneous Al <b>x</b>  | Simultaneous analog input channel where <b>x</b> is t he number of the channel. The sbRIO-9683 has s imultaneous AI channels 0 to 15 that you can <u>add to a project</u> .   |
| Sinking DOx               | Sinking digital output channel where <b>x</b> is the number of the channel. The sbRIO-9683 has sinking DO channels 0 to 23 that you can add to a project.                     |
| Sinking DO23:0            | Digital port consisting of sinking DO channels 0 t hrough 23. Channel 23 is returned in the MSB, a nd channel 0 is returned in the LSB.                                       |
| Sinking DO7:0             | Digital port consisting of sinking DO channels 0 t hrough 7. Channel 7 is returned in the MSB, and channel 0 is returned in the LSB.                                          |
| Sinking DO15:8            | Digital port consisting of sinking DO channels 8 t<br>hrough 15. Channel 15 is returned in the MSB, a<br>nd channel 8 is returned in the LSB.                                 |

| Sinking DO23:16         | Digital port consisting of sinking DO channels 16 through 23. Channel 23 is returned in the MSB, a nd channel 16 is returned in the LSB.                      |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sourcing P0 DI <b>x</b> | Sourcing digital input channel where <b>x</b> is the number of the channel. The sbRIO-9683 has sourcing P0 DI channels 0 to 13 that you can add to a project. |
| Sourcing P0 DI13:0      | Digital port consisting of sourcing DI P0 channel s 0 through 13. Channel 13 is returned in the MS B, and channel 0 is returned in the LSB.                   |
| Sourcing P0 DI7:0       | Digital port consisting of sourcing DI P0 channel s 0 through 7. Channel 7 is returned in the MSB, and channel 0 is returned in the LSB.                      |
| Sourcing P0 DI13:8      | Digital port consisting of sourcing DI P0channels 8 through 13. Channel 13 is returned in the MSB, and channel 8 is returned in the LSB.                      |
| Sourcing P1 DIx         | Sourcing digital input channel where <b>x</b> is the number of the channel. The sbRIO-9683 has sourcing P1 DI channels 0 to 13 that you can add to a project. |
| Sourcing P1 DI13:0      | Digital port consisting of sourcing DI P1 channel s 0 through 13. Channel 13 is returned in the MS B, and channel 0 is returned in the LSB.                   |
| Sourcing P1 DI7:0       | Digital port consisting of sourcing DI P1 channel s 0 through 7. Channel 7 is returned in the MSB, and channel 0 is returned in the LSB.                      |
| Sourcing P1 DI13:8      | Digital port consisting of sourcing DI P1 channel s 8 through 13. Channel 13 is returned in the MS B, and channel 8 is returned in the LSB.                   |

#### **Arbitration**

You can configure the arbitration settings for the LVTTL DIO, half-bridge DO, relay control DO, and sinking DO channels of this device in the <u>Advanced Code Generation</u> page of the FPGA I/O Properties dialog box. The default arbitration setting is Never Arbitrate for the LVTTL DIO, half-bridge DO, and relay control DO channels and Arbitrate if Multiple Requestors Only for the sinking DO channels.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for LVTTL DIO channels of this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data      | Refer to the <u>FPGA I/O Method Node (FPGA Module)</u> topic for a description of this method.                                                                                                                                                                                                                                                                                                                                                                        |
| Set Output Enable    | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method.                                                                                                                                                                                                                                                                                                                                                                                     |
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un til the next falling or rising edge of the digital sig nal. The <b>Timeout</b> input specifies in FPGA clock ticks how long the Wait on Any Edge method wa its for the next falling or rising edge. A value of 0 causes the method to time out immediately, a n egative value causes the method to wait indefinitely, and a positive value causes the method to wait for that number of clock ticks before timing out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un til the next falling edge of the digital signal. The <b>Timeout</b> input specifies in FPGA clock ticks ho w long the Wait on Falling Edge method waits for the next falling edge. A value of 0 causes the method to time out immediately, a negative value causes the method to wait indefinitely, and a positive value causes the method to wait for that number of clock ticks before timing out.                   |
| Wait on High Level   | Pauses the execution of the I/O Method Node un til the digital signal is high. The <b>Timeout</b> input specifies in FPGA clock ticks how long the Wait on High Level method waits for the next high level. A value of 0 causes the method to time out im mediately, a negative value causes the method to wait indefinitely, and a positive value causes the method to wait for that number of clock ticks before timing out.                                        |
| Wait on Low Level    | Pauses the execution of the I/O Method Node un til the digital signal is low. The <b>Timeout</b> input s                                                                                                                                                                                                                                                                                                                                                              |

|                     | pecifies in FPGA clock ticks how long the Wait on Low Level method waits for the next low level. A value of 0 causes the method to time out immediately, a negative value causes the method to wait indefinitely, and a positive value causes the method to wait for that number of clock ticks be fore timing out.                                                                                                                               |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un til the next rising edge of the digital signal. The <b>Timeout</b> input specifies in FPGA clock ticks ho w long the Wait on Rising Edge method waits for the next rising edge. A value of 0 causes the method to time out immediately, a negative value c auses the method to wait indefinitely, and a positive value causes the method to wait for that number of clock ticks before timing out. |

#### **RMC Methods**

Use the FPGA I/O Method Node to access the following RMC methods for this device.

| Method       | Description                                                                               |
|--------------|-------------------------------------------------------------------------------------------|
| Check Status | Returns a Boolean value that indicates whether the half-bridge DO on the device is ready. |

# **I/O Properties**

Use the FPGA I/O Property Node to access the following I/O properties for this device.

| Property      | Description                                                    |
|---------------|----------------------------------------------------------------|
| Voltage Range | Returns the input range for a simultaneous anal og input bank. |

# **RMC Properties**

Use the FPGA I/O Property Node to access the following RMC properties for this device.

| Property | Description |
|----------|-------------|
|          |             |

| Voltage Range Simultaneous Al <b>x:x</b> | Sets the input range for a simultaneous analog in put bank as either ±5 V or ±10 V where <b>x</b> :x is the bank. This method overwrites the value you configure in the RIO Mezzanine Card Properties dialog box. |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the high-speed DO channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box.

Avoiding Timing Uncertainty with the NI 9683 (FPGA Interface)

Follow these guidelines to avoid introducing timing uncertainty into scanned AI Node and AO Node method calls.

- Use a single I/O Node to access scanned AI and AO operations to ensure proper sequencing.
- Do not perform the following operations concurrently:
  - Scanned AI Node call
  - AO Node call



**Note** Simultaneous AI on the NI 9683 does not affect scanned AI and AO and is not affected by scanned AI and AO.

RIO Mezzanine Card Properties Dialog Box for the NI 9683 (FPGA Interface)

Right-click an NI 9683 RIO Mezzanine Card (RMC) in the **Project Explorer** window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure an RMC.

This dialog box includes the following components:

• Name—Specifies the name of the RMC, which appears in the **Project Explorer** window. LabVIEW assigns a default name to the device. You can use this field to give the device a descriptive name.

- Type—Specifies the type of RMC. You cannot change this option.
- Scaling Mode—Sets the scaling mode for the RMC. Select Scaled if you want the FPGA I/O Node to return scaled, fixed-point data from the device in units of volts. The fixed-point data is signed, with a word length of 20 bits and an integer word length of 5 bits for simultaneous AI and unsigned, with a word length of 16 bits and an integer word length of 3 bits for scanned AI and AO. Select **Raw** if you want the FPGA I/O Node to return unscaled, binary data from the device. If you select **Raw**, you must scale the analog input values in the host VI. The default is **Scaled**.
- Simultaneous AI Default Voltage Range—Specifies the input range for each simultaneous analog input bank. The NI 9683 contains eight banks consisting of two channels each.
- Sinking DO Disable Arbitration—Place a checkmark in this checkbox if you want to change the arbitration setting to <u>Never Arbitrate</u> and reduce the amount of FPGA logic used by VIs. Check this box only if you are sure that the design of the FPGA VI will never allow more than one digital function to execute at the same time, even on different channels. If more than one digital function could execute simultaneously in the FPGA VI, leave the box unchecked to keep the default Arbitrate if Multiple Requestors Only arbitration setting.
- LVTTL DIO Initial Line Direction—Sets the initial line direction for each LVTTL DIO channel to input or output. The default is input.

Scaling NI 9683 Analog Input Values (FPGA Interface)

Set the Scaling Mode to Scaled in the RIO Mezzanine Card Properties dialog box for the NI 9683 if you want the FPGA I/O Node to return scaled, fixed-point data for the device. If you set the **Scaling Mode** to **Raw**, the FPGA I/O Node returns unscaled, binary values for the NI 9683 that you can convert into volts using the following equations. You must convert these values in the host VI

#### Scanned Al

Use the following equation to convert binary values into volts for the scanned AI on the NI 9683.

**Volts = Binary Value** × 5 V ÷ 4096

where

**Binary Value** is the signed or unsigned value returned by the FPGA I/O Node

Simultaneous Al

Use the following equations to convert binary values into volts for the simultaneous AI on the NI 9683.

±10 V Range

**Volts = Binary Value** × 20 V ÷ 4096

where

**Binary Value** is the signed or unsigned value returned by the FPGA I/O Node

±5 V Range

**Volts = Binary Value** × 10 V ÷ 4096

where

**Binary Value** is the signed or unsigned value returned by the FPGA I/O Node

Scaling NI 9683 Analog Output Values (FPGA Interface)

Set the **Scaling Mode** to **Scaled** in the **RIO Mezzanine Card Properties** dialog box for the NI 9683 if you want the <u>FPGA I/O Node</u> to accept <u>fixed-point</u> data in volts when writing to the device. If you set the **Scaling Mode** to **Raw**, the FPGA I/O Node accepts only binary values. You can convert output voltage values to binary values using the following equation. You must convert these values in the host VI.

**Binary Value = Volts** × 4096 ÷ 5 V

where

**Binary Value** is the value you write to the FPGA I/O Node

sbRIO-9684

RIO Mezzanine Card, 16-bit General Purpose Inverter Controller

# Software Reference (?)

FPGA Interface

# Hardware Documentation (?)

sbRIO-9684 hardware documentation on ni.com/manuals



Note Use the sbRIO-9684 with only the sbRIO-9607.

#### sbRIO-9684 Pinout



sbRIO-9684 (FPGA Interface)

**RIO Mezzanine Card** 

16-bit General Purpose Inverter Controller

# FPGA I/O Node

You can use an FPGA I/O Node, configured for reading and writing, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal                | Description                                                                                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AOx                     | Analog output channel where <b>x</b> is the number of the channel. The sbRIO-9684 has AO channels 0 to 7 that you can <u>add to a project</u> .                            |
| Half-Bridge DO <b>x</b> | Half-bridge digital output channel where <b>x</b> is th e number of the channel. The sbRIO-9684 has H alf-bridge DO channels 0 to 13 that you can <u>add</u> to a project. |
| Half-Bridge DO13:0      | Digital port consisting of Half-bridge DO channe ls 0 through 13. Channel 13 is returned in the MS B, and channel 0 is returned in the LSB.                                |
| Half-Bridge DO7:0       | Digital port consisting of Half-bridge DO channe ls 0 through 7. Channel 7 is returned in the MSB, and channel 0 is returned in the LSB.                                   |
| Half-Bridge DO13:8      | Digital port consisting of Half-bridge DO channe ls 8 through 13. Channel 13 is returned in the MS B, and channel 8 is returned in the LSB.                                |
| LVTTL DIOx              | LVTTL digital input/output channel where <b>x</b> is the number of the channel. The sbRIO-9684 has LV TTL DIO channels 0 to 31 that you can <u>add to a project</u> .      |
| LVTTL DIO7:0            | Digital port consisting of LVTTL DIO channels 0 t hrough 7. Channel 7 is returned in the MSB, and channel 0 is returned in the LSB.                                        |

| LVTTL DIO15:8             | Digital port consisting of LVTTL DIO channels 8 t hrough 15. Channel 15 is returned in the MSB, a nd channel 8 is returned in the LSB.                                        |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LVTTL DIO23:16            | Digital port consisting of LVTTL DIO channels 16 through 23. Channel 23 is returned in the MSB, a nd channel 16 is returned in the LSB.                                       |
| LVTTL DIO31:24            | Digital port consisting of LVTTL DIO channels 24 through 31. Channel 31 is returned in the MSB, a nd channel 24 is returned in the LSB.                                       |
| Relay Control DO <b>x</b> | Relay control digital output channel where <b>x</b> is t he number of the channel. The sbRIO-9684 has r elay control DO channels 0 to 3 that you can <u>add</u> to a project. |
| Relay Control DO3:0       | Digital port consisting of relay control DO channels 0 through 3. Channel 3 is returned in the MS B, and channel 0 is returned in the LSB.                                    |
| Scanned Al <b>x</b>       | Scanned analog input channel where <b>x</b> is the number of the channel. The sbRIO-9684 has scanned AI channels 0 to 7 that you can <u>add to a project</u> .                |
| Simultaneous Al <b>x</b>  | Simultaneous analog input channel where <b>x</b> is t he number of the channel. The sbRIO-9684 has s imultaneous AI channels 0 to 15 that you can <u>add to a project</u> .   |
| Sinking DOx               | Sinking digital output channel where <b>x</b> is the number of the channel. The sbRIO-9684 has sinking DO channels 0 to 23 that you can add to a project.                     |
| Sinking DO23:0            | Digital port consisting of sinking DO channels 0 t hrough 23. Channel 23 is returned in the MSB, a nd channel 0 is returned in the LSB.                                       |
| Sinking DO7:0             | Digital port consisting of sinking DO channels 0 t hrough 7. Channel 7 is returned in the MSB, and channel 0 is returned in the LSB.                                          |
| Sinking DO15:8            | Digital port consisting of sinking DO channels 8 t<br>hrough 15. Channel 15 is returned in the MSB, a<br>nd channel 8 is returned in the LSB.                                 |

| Sinking DO23:16         | Digital port consisting of sinking DO channels 16 through 23. Channel 23 is returned in the MSB, a nd channel 16 is returned in the LSB.                      |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sourcing P0 DI <b>x</b> | Sourcing digital input channel where <b>x</b> is the number of the channel. The sbRIO-9684 has sourcing P0 DI channels 0 to 13 that you can add to a project. |
| Sourcing P0 DI13:0      | Digital port consisting of sourcing DI P0 channel s 0 through 13. Channel 13 is returned in the MS B, and channel 0 is returned in the LSB.                   |
| Sourcing P0 DI7:0       | Digital port consisting of sourcing DI P0 channel s 0 through 7. Channel 7 is returned in the MSB, and channel 0 is returned in the LSB.                      |
| Sourcing P0 DI13:8      | Digital port consisting of sourcing DI P0channels 8 through 13. Channel 13 is returned in the MSB, and channel 8 is returned in the LSB.                      |
| Sourcing P1 DIx         | Sourcing digital input channel where <b>x</b> is the number of the channel. The sbRIO-9684 has sourcing P1 DI channels 0 to 13 that you can add to a project. |
| Sourcing P1 DI13:0      | Digital port consisting of sourcing DI P1 channel s 0 through 13. Channel 13 is returned in the MS B, and channel 0 is returned in the LSB.                   |
| Sourcing P1 DI7:0       | Digital port consisting of sourcing DI P1 channel s 0 through 7. Channel 7 is returned in the MSB, and channel 0 is returned in the LSB.                      |
| Sourcing P1 DI13:8      | Digital port consisting of sourcing DI P1 channel<br>s 8 through 13. Channel 13 is returned in the MS<br>B, and channel 8 is returned in the LSB.             |

You can configure the arbitration settings for the LVTTL DIO, half-bridge DO, relay control DO, and sinking DO channels of this device in the Advanced Code Generation page of the FPGA I/O Properties dialog box. The default arbitration setting is Never Arbitrate for the LVTTL DIO, half-bridge DO, and relay control DO channels and Arbitrate if Multiple Requestors Only for the sinking DO channels.

# I/O Methods

Use the <u>FPGA I/O Method Node</u> to access the following I/O methods for LVTTL DIO channels of this device.

| Method               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set Output Data      | Refer to the <u>FPGA I/O Method Node (FPGA Module)</u> topic for a description of this method.                                                                                                                                                                                                                                                                                                                                                                        |
| Set Output Enable    | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method.                                                                                                                                                                                                                                                                                                                                                                                     |
| Wait on Any Edge     | Pauses the execution of the I/O Method Node un til the next falling or rising edge of the digital sig nal. The <b>Timeout</b> input specifies in FPGA clock ticks how long the Wait on Any Edge method wa its for the next falling or rising edge. A value of 0 causes the method to time out immediately, a n egative value causes the method to wait indefinitely, and a positive value causes the method to wait for that number of clock ticks before timing out. |
| Wait on Falling Edge | Pauses the execution of the I/O Method Node un til the next falling edge of the digital signal. The <b>Timeout</b> input specifies in FPGA clock ticks ho w long the Wait on Falling Edge method waits fo r the next falling edge. A value of 0 causes the method to time out immediately, a negative value causes the method to wait indefinitely, and a positive value causes the method to wait for that number of clock ticks before timing out.                  |
| Wait on High Level   | Pauses the execution of the I/O Method Node un til the digital signal is high. The <b>Timeout</b> input specifies in FPGA clock ticks how long the Wait on High Level method waits for the next high leve l. A value of 0 causes the method to time out im mediately, a negative value causes the method to wait indefinitely, and a positive value causes the method to wait for that number of clock ticks before timing out.                                       |
| Wait on Low Level    | Pauses the execution of the I/O Method Node un til the digital signal is low. The <b>Timeout</b> input s                                                                                                                                                                                                                                                                                                                                                              |

|                     | pecifies in FPGA clock ticks how long the Wait on Low Level method waits for the next low level. A value of 0 causes the method to time out immediately, a negative value causes the method to wait indefinitely, and a positive value causes the method to wait for that number of clock ticks be fore timing out.                                                                                                                               |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wait on Rising Edge | Pauses the execution of the I/O Method Node un til the next rising edge of the digital signal. The <b>Timeout</b> input specifies in FPGA clock ticks ho w long the Wait on Rising Edge method waits for the next rising edge. A value of 0 causes the method to time out immediately, a negative value c auses the method to wait indefinitely, and a positive value causes the method to wait for that number of clock ticks before timing out. |

#### **RMC Methods**

Use the FPGA I/O Method Node to access the following RMC methods for this device.

| Method | Description                                                                               |
|--------|-------------------------------------------------------------------------------------------|
|        | Returns a Boolean value that indicates whether the half-bridge DO on the device is ready. |

# I/O Properties

Use the FPGA I/O Property Node to access the following I/O properties for this device.

| Property                | Description                                             |
|-------------------------|---------------------------------------------------------|
| LSB Weight (±10V range) | Returns the LSB weight in V/LSB for the ±10V range.     |
| LSB Weight (±5V range)  | Returns the LSB weight in V/LSB for the ±5V rang e.     |
| Offset (±10V range)     | Returns the calibration offset in V for the ±10V range. |
| Offset (±5V range)      | Returns the calibration offset in V for the ±5V range.  |

| Voltage Range | Returns the input range for a simultaneous anal |
|---------------|-------------------------------------------------|
|               | og input bank.                                  |

## **RMC Properties**

Use the <u>FPGA I/O Property Node</u> to access the following RMC properties for this device.

| Property                                 | Description                                                                                                                                                                                                         |
|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Voltage Range Simultaneous Al <b>x:x</b> | Sets the input range for a simultaneous analog i nput bank as either ±5 V or ±10 V where <b>x</b> :x is the bank. This method overwrites the value you c onfigure in the RIO Mezzanine Card Properties d ialog box. |

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the high-speed DO channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box.

Avoiding Timing Uncertainty with the sbRIO-9684 (FPGA Interface)

Follow these guidelines to avoid introducing timing uncertainty into scanned AI Node and AO Node method calls.

- Use a single I/O Node to access scanned AI and AO operations to ensure proper sequencing.
- Do not perform the following operations concurrently:





**Note** Simultaneous AI on the sbRIO-9684 does not affect scanned AI and AO and is not affected by scanned AI and AO.

RIO Mezzanine Card Properties Dialog Box for the sbRIO-9684 (FPGA Interface)

Right-click an sbRIO-9684 RIO Mezzanine Card (RMC) in the Project Explorer window and select **Properties** from the shortcut menu to display this dialog box.

Use this dialog box to configure an RMC.

This dialog box includes the following components:

- Name—Specifies the name of the RMC, which appears in the Project **Explorer** window. LabVIEW assigns a default name to the device. You can use this field to give the device a descriptive name.
- Type—Specifies the type of RMC. You cannot change this option.
- Scaling Mode—Sets the scaling mode for the RMC. Select Scaled if you want the <u>FPGA I/O Node</u> to return scaled, <u>fixed-point</u> data from the device in units of volts. The fixed-point data is signed, with a word length of 20 bits and an integer word length of 5 bits for simultaneous AI and unsigned, with a word length of 16 bits and an integer word length of 3 bits for scanned AI and AO. Select Raw if you want the FPGA I/O Node to return unscaled, binary data from the device. If you select **Raw**, you must scale the analog input values in the host VI. The default is **Scaled**.
- Simultaneous AI Default Voltage Range—Specifies the input range for each simultaneous analog input bank. The sbRIO-9684 contains eight banks consisting of two channels each.
- Sinking DO Disable Arbitration—Place a checkmark in this checkbox if you want to change the arbitration setting to Never Arbitrate and reduce the amount of FPGA logic used by VIs. Check this box only if you are sure that the design of the FPGA VI will never allow more than one digital function to execute at the same time, even on different channels. If more than one digital function could execute simultaneously in the FPGA VI, leave the box unchecked to keep the default Arbitrate if Multiple Requestors Only arbitration setting.
- LVTTL DIO Initial Line Direction—Sets the initial line direction for each LVTTL DIO channel to input or output. The default is input.

Scaling sbRIO-9684 Analog Input Values (FPGA Interface)

Set the **Scaling Mode** to **Scaled** in the **RIO Mezzanine Card Properties** dialog box for the NI 9684 if you want the <u>FPGA I/O Node</u> to return scaled, <u>fixed-point</u> data for the device. If you set the **Scaling Mode** to **Raw**, the FPGA I/O Node returns unscaled, binary values for the NI 9684 that you can convert into volts using the following equations. You must convert these values in the host VI

#### Scanned Al

Use the following equation to convert binary values into volts for the scanned AI on the sbRIO-9684.

**Volts = Binary Value** × 5 V ÷ 4096

where

**Binary Value** is the signed or unsigned value returned by the FPGA I/O Node

#### Simultaneous Al

Use the following equations to convert binary values into volts for the simultaneous AI on the sbRIO-9684 for both  $\pm 10$ V and  $\pm 5$ V ranges.

**Volts** = (**Binary Value** × LSB Weight + Offset)\*

where

**Binary Value** is the signed value returned by the FPGA I/O Node

**LSB Weight** is the value returned by the LSB Weight property

**Offset** is the value returned by the Offset property

If you do not want to read the LSB Weight and Offset values from the module, you can convert to uncalibrated engineering units by using the following values for Offset and LSB Weight:

Offset = 0

LSB Weight = Typical Input Span  $\div 2^{ADC Resolution}$ 

where

Typical Input Span is 20.832V for ±10V range and 10.416V for ±5V range

**ADC Resolution** is the ADC resolution value in the hardware documentation for the module

\*LSB Weight and Offset are formatted and cannot be used as is. Refer to the Binary to Nominal VI in the LabVIEW\examples\CompactRIO\RMC Specific\NI 9684\NI 9684 High Speed Acquisition\NI 9684 High Speed Ac quisition\NI 9684 High Speed Acquisition.lvprojforan example on how to convert the LSB Weight and Offset to the correct format.

Scaling sbRIO-9684 Analog Output Values (FPGA Interface)

Set the Scaling Mode to Scaled in the RIO Mezzanine Card Properties dialog box for the NI 9684 if you want the FPGA I/O Node to accept fixed-point data in volts when writing to the device. If you set the **Scaling Mode** to **Raw**, the FPGA I/O Node accepts only binary values. You can convert output voltage values to binary values using the following equation. You must convert these values in the host VI.

**Binary Value = Volts** × 4096 ÷ 5 V

where

**Binary Value** is the value you write to the FPGA I/O Node

sbRIO-9694

RIO Mezzanine Card, 96 channel digital I/O breakout board

**Software Reference (?)** 

FPGA Interface

#### sbRIO-9694 Pinout



sbRIO-9694 (FPGA Interface)

**RIO Mezzanine Card** 

96 channel digital I/O breakout board

# FPGA I/O Node

You can use an FPGA I/O Node, configured for reading and writing, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| DIOx     | Digital input/output channel where <b>x</b> is the number of the channel. The sbRIO-9694 has DIO channels 0 to 95 that you can <u>add to a project</u> . |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIO15:0  | Digital port consisting of DIO channels 0 throug<br>h 15. Channel 15 is returned in the MSB, and cha<br>nnel 0 is returned in the LSB.                   |
| DIO31:16 | Digital port consisting of DIO channels 16 through 31. Channel 31 is returned in the MSB, and channel 16 is returned in the LSB.                         |
| DIO47:32 | Digital port consisting of DIO channels 32 through 47. Channel 47 is returned in the MSB, and channel 32 is returned in the LSB.                         |
| DIO63:48 | Digital port consisting of DIO channels 48 through 63. Channel 63 is returned in the MSB, and channel 48 is returned in the LSB.                         |
| DIO79:64 | Digital port consisting of DIO channels 64 through 79. Channel 79 is returned in the MSB, and channel 64 is returned in the LSB.                         |
| DIO95:80 | Digital port consisting of DIO channels 80 through 95. Channel 95 is returned in the MSB, and channel 80 is returned in the LSB.                         |

You can configure the arbitration settings for the DIO channels of this device in the Advanced Code Generation page of the FPGA I/O Properties dialog box. The default arbitration setting is Never Arbitrate.

# I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method            | Description                                                                       |
|-------------------|-----------------------------------------------------------------------------------|
| Set Output Data   | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |
| Set Output Enable | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |

#### **Module Methods**

This device does not support any module methods.

# **Properties**

This device does not support any properties.

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box.

sbRIO-9697

**RIO Mezzanine Card** 

2-slot C Series, 24 3.3 V DIO channels

#### **Software Reference (?)**

FPGA Interface



**Note** Use the sbRIO-9697 with only sbRIO-9607/9627 devices.

#### sbRIO-9697 Pinout



sbRIO-9697 (FPGA Interface)

2-slot C Series RIO Mezzanine Card

# FPGA I/O Node

You can use an FPGA I/O Node, configured for reading and writing, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description |
|----------|-------------|
|----------|-------------|

| DIOx     | Digital input/output channel where <b>x</b> is the number of the channel. The sbRIO-9697 has DIO channels 0 to 23 that you can <u>add to a project</u> . |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIO15:0  | Digital port consisting of DIO channels 0 throug<br>h 15. Channel 15 is returned in the MSB, and cha<br>nnel 0 is returned in the LSB.                   |
| DIO23:16 | Digital port consisting of DIO channels 16 through 23. Channel 23 is returned in the MSB, and channel 16 is returned in the LSB.                         |

You can configure the arbitration settings for the DIO channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. The default arbitration setting is <u>Never Arbitrate</u>.

## I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method            | Description                                                                       |
|-------------------|-----------------------------------------------------------------------------------|
| Set Output Data   | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |
| Set Output Enable | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |

#### **Module Methods**

This device does not support any module methods.

# **Properties**

This device does not support any properties.

# Single-Cycle Timed Loop

This device supports the <u>single-cycle Timed Loop</u>. Configure the number of output synchronizing registers for the channels of this device in the <u>Advanced Code</u> <u>Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. Configure the number of

input synchronizing registers for the channels of this device in the <u>Advanced Code</u> Generation page of the FPGA I/O Node Properties dialog box.

sbRIO-9698

**RIO Mezzanine Card** 

1-Slot C Series, Secondary Ethernet Port, 24 3.3 V DIO channels

### Software Reference (?)

**FPGA Interface** 



Note Use the sbRIO-9698 with only sbRIO-9607/9627 devices.

#### Pin 1 0 Θ Θ 0 0 J1, DIO D GND 2 DIO0 D GND DIO1 D GND DIO2 D GND 8 DIO3 D GND 9 10 DIO4 D GND 12 DIO5 11 13 14 DIO6 D GND D GND DIO7 D GND 17 DIO8 18 D GND 19 20 DIO9 D GND 21 DIO10 22 D GND 23 24 DIO11 25 26 DIO12 D GND D GND 27 28 DIO13 D GND 29 30 DIO14 D GND 31 32 DIO15 D GND 33 34 DIO16 35 D GND 36 DIO17 D GND 37 38 DIO18 D GND 39 40 DIO19 41 42 DIO20 D GND

#### sbRIO-9698 Pinout

sbRIO-9698 (FPGA Interface)

DI021

DI022

48 DIO23

50 +5V

1-Slot C Series, Secondary Ethernet Port, 24 3.3 V DIO channels

# FPGA I/O Node

43 44

45

47

49

46

D GND

D GND

D GND

+5V

You can use an FPGA I/O Node, configured for reading and writing, with this device.

## **Terminals in Software**

Use the FPGA I/O Node to access the following terminals for this device.

| Terminal | Description                                                                                                                                              |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIOx     | Digital input/output channel where <b>x</b> is the number of the channel. The sbRIO-9698 has DIO channels 0 to 23 that you can <u>add to a project</u> . |
| DIO15:0  | Digital port consisting of DIO channels 0 throug<br>h 15. Channel 15 is returned in the MSB, and cha<br>nnel 0 is returned in the LSB.                   |
| DIO23:16 | Digital port consisting of DIO channels 16 through 23. Channel 23 is returned in the MSB, and channel 16 is returned in the LSB.                         |

You can configure the arbitration settings for the DIO channels of this device in the Advanced Code Generation page of the FPGA I/O Properties dialog box. The default arbitration setting is Never Arbitrate.

## I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods for this device.

| Method            | Description                                                                       |
|-------------------|-----------------------------------------------------------------------------------|
| Set Output Data   | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |
| Set Output Enable | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |

#### **Module Methods**

This device does not support any module methods.

#### **Properties**

This device does not support any properties.

# Single-Cycle Timed Loop

This device supports the single-cycle Timed Loop. Configure the number of output synchronizing registers for the channels of this device in the Advanced Code

<u>Generation</u> page of the <u>FPGA I/O Properties</u> dialog box. Configure the number of input synchronizing registers for the channels of this device in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O Node Properties</u> dialog box.

NI Digital I/O Mezzanine Card

96 DIO channels

#### Software Reference (?)

**FPGA Interface** 

NI Digital I/O Mezzanine Card (FPGA Interface)

96 DIO channels

## FPGA I/O Node

You can use an FPGA I/O Node, configured for reading and writing, with this device.

#### **Terminals in Software**

Use the FPGA I/O Node to access the following terminals.

| Terminal | Description                                                                                                                                                   |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIOx     | Digital input/output channel where x is the number of the channel. The digital I/O mezzanine card exposes DIO channels 0 to 95 that you can add to a project. |
| DIO15:0  | Digital port consisting of DIO channels 0 throug h 15. Channel 15 is returned in the MSB, and channel 0 is returned in the LSB.                               |
| DIO31:16 | Digital port consisting of DIO channels 16 through 31. Channel 31 is returned in the MSB, and channel 16 is returned in the LSB.                              |
| DIO47:32 | Digital port consisting of DIO channels 32 through 47. Channel 47 is returned in the MSB, and channel 32 is returned in the LSB.                              |

| DIO63:48 | Digital port consisting of DIO channels 48 throu gh 63. Channel 63 is returned in the MSB, and channel 48 is returned in the LSB. |
|----------|-----------------------------------------------------------------------------------------------------------------------------------|
| DIO79:64 | Digital port consisting of DIO channels 64 throu gh 79. Channel 79 is returned in the MSB, and channel 64 is returned in the LSB. |
| DIO95:80 | Digital port consisting of DIO channels 80 throu gh 95. Channel 95 is returned in the MSB, and channel 80 is returned in the LSB. |

You can configure the arbitration settings for the DIO channels in the Advanced Code Generation page of the FPGA I/O Properties dialog box. The default arbitration setting is Never Arbitrate.

## I/O Methods

Use the FPGA I/O Method Node to access the following I/O methods.

| Method            | Description                                                                       |
|-------------------|-----------------------------------------------------------------------------------|
| Set Output Data   | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |
| Set Output Enable | Refer to the <u>FPGA I/O Method Node</u> topic for a d escription of this method. |

#### **Module Methods**

This device does not support any module methods.

# **Properties**

This device does not support any properties.

# Single-Cycle Timed Loop

This device supports the single-cycle Timed Loop. Configure the number of output synchronizing registers for the channels in the Advanced Code Generation page of the FPGA I/O Properties dialog box. Configure the number of input synchronizing

registers for the channels in the <u>Advanced Code Generation</u> page of the <u>FPGA I/O</u> <u>Node Properties</u> dialog box.