Skip to content

Latest commit

 

History

History
301 lines (155 loc) · 10.4 KB

File metadata and controls

301 lines (155 loc) · 10.4 KB

Badge Badge Badge Badge

CAN Transceivers on Jetson AGX Xavier

Description

In this repository you will find a simplified method of installing CAN transceivers on the Jetson AGX Xavier board. After much research and study, I created these steps in the way I would have liked to find when I was doing the installation.


Enabling CAN

Leave the board in "full" mode -> MODE 30W ALL

This mode can be found in the upper right corner of the screen, in the power mode options, the image below shows where these options are.



To perform the installation and configuration of the CAN transceivers, you must enter root mode on the AGX Xavier board to perform the modifications with privileges. Root mode is accessed by the command:

sudo su

Confirm that the channels are not active with the ifconfig command, which will return all the set network ports of the card. At this point no can0 or can1 should appear.

The CAN Transceiver used was the sn65hvd230, its supply voltage is 3.3V. Learn more by reading the datasheet.



For the bus, we used two CAN Transceivers connected to the board and mounted on a protoboard as you can see in the pictures below.



Transceivers




CAN Bus
The CAN Bus is the last two bottom rows of the protoboard


Connections

CRX ------ Purple
CTX ------ Green (CAN1) and Yellow (CAN0)
CANH ----- White
CANL ----- White with Green
Ground --- Black/Brown
VCC ------ Bluen/Orange


Connect the CAN Transceivers to the board

AGX Xavier's doors are referenced by the image below or access the site to see the table in better quality.



Connect the transceivers according to the image below, tx to tx and rx to rx. I know it gets confusing when I say tx to tx, but in short, connect CAN0_DIN to the rx of the transceiver and CAN0_DOUT to the tx of the transceiver. The can1 connections follow the same logic. VCC of the transceiver to the 3.3V pin of the board, as well as GND of the transceiver to GND of the board.



Check the status of the can-controllers by command:

cat /proc/device-tree/mttcan\@c310000/status

@c310000 - endereço do can-controller 1

@c320000 - endereço do can-controller 2

The return from the command to be "okay".


Installing Busybox

Install the busybox tool to configure the pinmux values, which is the pin reference on Xavier's bus. The installation is done by the command:

apt-get install busybox


Setting the Addresses

After the installation, it is time to configure the addresses. To configure the addresses, run the commands below and check that the values are according to the specific card, this information is located in the table below in the Pinmux property.

Property Jetson Xavier NX & Jetson TX2 NX Jetson AGX Xavier series Jetson TX2
Number of controllers 1 2 2
Controller base address mttcan@c310000 mttcan@c310000 mttcan@c320000 mttcan@c310000 mttcan@c320000
Pins on Jetson carrier Board J17;
CAN_RX: [1]
CAN_TX: [2]
J30 (40-pin header):
CAN0_DIN: [29]
CAN0_DOUT: [31]
CAN1_DIN: [37]
CAN1_DOUT: [33]
J26 (30-pin header):
CAN0_RX: [5]
CAN0_TX: [7]
CAN1_RX: [15]
CAN1_TX: [17]
Pinmux
can0_din
Address:
Value:

0x0c303020
0x0458

0x0c303018
0x0458

0x0c303020
0x0458
can0_dout
Address:
Value:

0x0c303018
0x0400

0x0c303010
0x0400

0x0c303018
0x0400
can1_din
Address:
Value:
n/a
0x0c303008
0x0458

0x0c303010
0x0458
can1_dout
Address:
Value:
n/a
0x0c303000
0x0400

0x0c303008
0x0400
Default pin configuration SFIO: CAN functionality GPIO SFIO: CAN functionality

Then run this command busybox devmem 0x0c303020 w 0x458 for each port, notice that there are four different ones. 

0x0c303020 - address taken from the table for the TX2 and Xavier NX card, remember that we work with the Xavier AGX, so the values are different.

0x458 - value

The table can also be found from the documentation in CAN (Controller Area Network). Enable the pins to use CAN through the Jetson-IO tool interface, please read the documentation for more information.

Run the command below to open the interface.

sudo /opt/nvidia/jetson-io/jetson-io.py

The interface will be opened and you will see the screen below.



Use the up, down and enter arrows to navigate between options. Select "Configure 40-pin expansion header" to modify the pins. Check if the screen below was opened. 



In this screen you will select with up/down and next enter to define the pin to mark on can0 and can1 like the image below.



Go back to the main screen with the back command, check if different options appear and if the CAN inputs and outputs on the bus are listed like the image below.



In the options, select "Save and reboot to reconfigure pins", this option will leave the pins pre-set every time the board is booted and will reboot the board.



After the board is completely connected, perform the next steps....


Enabling Kernel Drivers

The next step is to load the Kernel drivers and in the following order, follow the order described below:

  1. Insert the CAN BUS subsystem support module: modprobe can

  2. Insert the raw CAN protocol module (CAN-ID filtering):

    modprobe can_raw

  3. Add real CAN interface support (for Jetson, mttcan):

    modprobe mttcan


CAN network management

To use the network, you need to manage the network. This management is done by the commands below, one for can0 and one for can1.  These example commands set the network interface to use FD (Flexible Data) mode with a bus bit rate of 500 kbps and a data bit rate of 1 Mbps, enter the commands:

ip link set can0 up type can bitrate 500000 dbitrate 1000000 berr-reporting on fd on

ip link set can1 up type can bitrate 500000 dbitrate 1000000 berr-reporting on fd on

Verify that the ports appeared by the ifconfig command, it should return the CAN ports in the <UP, RUNNIG< NOARP> state. We can validate this by looking at the image below:




Installing the can-utils

It is necessary to install the can-utils library to use some commands like cansend (sends message over the bus) and candump (monitors and displays the message).

Now install the CAN utility library by the command below:

apt-get install can-utils


After performing these steps, it is time to test the CAN-Bus. To send data from can0/can1, use the command below, but define what the channel will be:

cansend can0 123#abcdabcd - single message

cangen -v can0 - automatic random messages

Finally, to monitor, open another terminal and run the command and select the channel to monitor:

candump can1


For more details, I recommend reading the documentation about.


Natanael Vitorino