Test all the RB interfaces in 10 mins in command Line
Refer the Hardware and System reference manual to check out the PIN Numbers and PORT numbers etc. of respective interfaces.
Hardware manual
In case of any doubts you can Ask questions in RuggedBoard forum.
Targeted Hardware | SOM : phyCORE - i.MX 6UL CB : RuggedBoard - i.MX6UL |
Targeted Software | - barebox v2022.02.0 - Linux Mainline Kernel v5.15.35(LTS kernel) - Yocto 4.0.1 (kirkstone) |
Description
To test the GPIO Device functionality in Kernel.
Required Hardware
RuggedBoard - i.MX6UL
Test Case:
Step-1: To export the gpio
$ echo 43 > /sys/class/gpio/export
Step-2: To set the in/output of the gpio to the file direction.
$ echo out > /sys/class/gpio/gpio43/direction
Step-3: To set the gpio value to 1 (off) , indicating the GPIO pin to be set to a active low level.
$ echo 1 > /sys/class/gpio/gpio43/value
Step-4: To set the gpio value to 0 (on) , indicating the GPIO pin to be set to a active low level.
$ echo 0 > /sys/class/gpio/gpio43/value
Here GPIO value can be calculated as :
VALUE = ( GPIO_BANK - 1)*32 + GPIO_Value
VALUE = (2 - 1)*32 + 11
= 32 + 11
= 43
Note : GPIO calculation will vary for board to board crosscheck with boards TRM.
Expected o/p
root@ruggedboard-imx6ul:~# echo 43 > /sys/class/gpio/export
root@ruggedboard-imx6ul:~# echo out > /sys/class/gpio/gpio43/direction
root@ruggedboard-imx6ul:~# echo 1 > /sys/class/gpio/gpio43/value
root@ruggedboard-imx6ul:~# echo 0 > /sys/class/gpio/gpio43/value
root@ruggedboard-imx6ul:~# echo 1 > /sys/class/gpio/gpio43/value
********************************************************************************
root@ruggedboard-imx6ul:~# echo 44 > /sys/class/gpio/export
root@ruggedboard-imx6ul:~# echo out > /sys/class/gpio/gpio44/direction
root@ruggedboard-imx6ul:~# echo 1 > /sys/class/gpio/gpio44/value
root@ruggedboard-imx6ul:~# echo 0 > /sys/class/gpio/gpio44/value
root@ruggedboard-imx6ul:~# echo 1 > /sys/class/gpio/gpio44/value
You can use remaining two user LED or any GPIO PIN mentioned in the Hardware manual with the same method. In case of any doubt post your detailed question into the RuggedBoard forum.
Description:
To test the RS232/UART Device functionality using two boards.
Required Hardware
RuggedBoard-i.MX6UL
USB CABLE
UART PORT
PATCH CORDS
Test Case 1 (Check the UART node in /dev/)
Boot the board from NAND/MMC.
Check weather the node is created in /dev
$ ls /dev/ttymxc1
Expected o/p
root@ruggedboard-imx6ul:~# ls /dev/ttymxc1
/dev/ttymxc1
Test Case 2 (Check the UART communication between 2 devices)
Boot the board from NAND/MMC, Check the Log file whether node is created or not.
Open microcom on both the boards and send data.
$ microcom -s <baud-rate> /dev/ttyS3
To establish a serial communication session with a device connected to the second UART interface (ttymxc1).
$ microcom -s 115200 /dev/ttymxc1
Expected o/p
RB-Device-1:
root@ruggedboard-imx6ul:~# microcom -s 115200 /dev/ttymxc1
helllo phytec
RB-Device-2:
root@ruggedboard-imx6ul:~# microcom -s 115200 /dev/ttymxc1
ruggedboard.............
Description
To test the read and write functionality of i2c based eeprom
Required Hardware
RuggedBoard-i.MX6UL
USB cable
Step-by-step guide
To scan the i2c bus in device we use the command as
$ i2cdetect -y -r 0
Give the below command to write the data on eeprom
$ echo hello > /sys/class/i2c-dev/i2c-0/device/0-0052/eeprom
Please give the below command to read the data from eeprom.
$ cat /sys/class/i2c-dev/i2c-0/device/0-0052/eeprom
Expected Output
root@ruggedboard-imx6ul:~# i2cdetect -y -r 0
0 1 2 3 4 5 6 7 8 9 a b c d e f
00: -- -- -- -- -- -- -- -- -- -- -- -- --
10: -- -- -- -- -- -- -- -- 18 -- -- -- -- -- -- --
20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
50: -- -- UU -- -- -- -- -- -- -- 5a -- -- -- -- --
60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
70: -- -- -- -- -- -- 76 --
root@ruggedboard-imx6ul:~# echo hello > /sys/class/i2c-dev/i2c-0/device/0-0052/eeprom
root@ruggedboard-imx6ul:~# cat /sys/class/i2c-dev/i2c-0/device/0-0052/eeprom
hello ...
phytec.... welcome to ruggedboard community......
Description
To test the USB1 Port functionality using the dmesg in Kernel with Pen-drive.
To test the USB1 Port functionality in Kernel with Pen-drive to read and write the data.
To test the USB1 Port functionality in Kernel with USB host performance test.
Required Hardware
RuggedBoard-i.MX6UL
USB PORT/Hub. -USB Stick.
Prerequisite
USB-STICK should be detected.
Test Case 1 (Insert Pen drive check the dmesg log)
To check wheather the USB node
$ dmesg | tail
Expected o/p
root@ruggedboard-imx6ul:~# dmesg | tail
[ 3853.290339] scsi host0: usb-storage 1-1:1.0
[ 3854.410737] scsi 0:0:0:0: Direct-Access Mass Storage Device 1.00 PQ: 0 ANSI: 0 CCS
[ 3854.636262] sd 0:0:0:0: [sda] 31116288 512-byte logical blocks: (15.9 GB/14.8 GiB)
[ 3854.659172] sd 0:0:0:0: [sda] Write Protect is off
[ 3854.664128] sd 0:0:0:0: [sda] Mode Sense: 03 00 00 00
[ 3854.669346] sd 0:0:0:0: [sda] No Caching mode page found
[ 3854.674993] sd 0:0:0:0: [sda] Assuming drive cache: write through
[ 3854.755368] sda: sda1 sda2 sda3
[ 3854.857424] sd 0:0:0:0: [sda] Attached SCSI removable disk
[ 3879.173126] FAT-fs (sda1): Volume was not properly unmounted. Some data may be corrupt. Please run fsck.
root@ruggedboard-imx6ul:~#
Test Case 2 (Mount the Pen-drive and read and write the data)
Boot the board from NAND/MMC. After booting insert the USB Stick into Board USB port/USB-HUB, Check the Log file whether node is creadted or not using dmesg.
Once the node is detected, mount the node and do the read and write by typing the command given below.
$ mount /dev/sda1 /mnt/
$ cd /mnt
$ ls
Expected o/p
root@ruggedboard-imx6ul:~# mount /dev/sda
sda sda1 sda2 sda3
root@ruggedboard-imx6ul:~# mount /dev/sda1 /mnt/
[ 3879.173126] FAT-fs (sda1): Volume was not properly unmounted. Some data may be corrupt. Please run fsck.
root@ruggedboard-imx6ul:~# cd /mnt/
root@ruggedboard-imx6ul:mnt# ls
Image* imx8mp-phycore-no-spiflash.dtbo*
bootenv.txt* imx8mp-phycore-rpmsg.dtbo*
imx8mp-isi-csi1.dtbo* imx8mp-vm016-csi1-fpdlink.dtbo*
imx8mp-isi-csi2.dtbo* imx8mp-vm016-csi1.dtbo*
imx8mp-isp-csi1.dtbo* imx8mp-vm016-csi2-fpdlink.dtbo*
imx8mp-isp-csi2.dtbo* imx8mp-vm016-csi2.dtbo*
imx8mp-phyboard-pollux-1552.1.dtbo* imx8mp-vm017-csi1-fpdlink.dtbo*
imx8mp-phyboard-pollux-peb-av-010.dtbo* imx8mp-vm017-csi1.dtbo*
imx8mp-phyboard-pollux-peb-av-012.dtbo* imx8mp-vm017-csi2-fpdlink.dtbo*
imx8mp-phyboard-pollux-peb-wlbt-05.dtbo* imx8mp-vm017-csi2.dtbo*
imx8mp-phyboard-pollux-rdk.dtb* oftree*
imx8mp-phycore-no-eth.dtbo* tee.bin*
imx8mp-phycore-no-rtc.dtbo* write.c*
root@ruggedboard-imx6ul:mnt#
root@ruggedboard-imx6ul:mnt# cd
root@ruggedboard-imx6ul:~# umount /mnt/
root@ruggedboard-imx6ul:~#
Test Case 3 (USB host performance test)
Boot the board from NAND/MMC
After booting run the script file and insert the USB Stick into Board USB port/USB-HUB.
$ sh usb_host_test.sh
Expected o/p
root@ruggedboard-imx6ul:~# sh usb_host_test.sh
insert usb flash stick
usb 1-1: new full-speed USB device number 3 using at91_ohci
usb 1-1: New USB device found, idVendor=0781, idProduct=5567
usb 1-1: New USB device strings: Mfr=1, Product=2, SerialNumber=3
usb 1-1: Product: Cruzer Blade
usb 1-1: Manufacturer: SanDisk
usb 1-1: SerialNumber: 4C530001280707107415
usb-storage 1-1:1.0: USB Mass Storage device detected
scsi host0: usb-storage 1-1:1.0
scsi 0:0:0:0: Direct-Access SanDisk Cruzer Blade 1.00 PQ: 0 ANSI: 6
sd 0:0:0:0: [sda] 61341696 512-byte logical blocks: (31.4 GB/29.3 GiB)
sd 0:0:0:0: [sda] Write Protect is off
sd 0:0:0:0: [sda] Write cache: disabled, read cache: enabled, doesn't support DPO or FUA
sda:
sd 0:0:0:0: [sda] Attached SCSI removable disk
dmesg -c
hdparm -t /dev/sda
hdparm -T /dev/sda
dd if=/dev/urandom bs=1M count=32 of=/tmp/test.img
mount -o rw,uid=1000 /dev/sda1 /mnt
time cp /tmp/test.img /mnt/test.img
time sync
md5sum -c /tmp/test.md5
time cp /mnt/test.img /tmp/test.img
md5sum -c /tmp/test.md5
mount -o rw,uid=1000,remount,sync /dev/sda1
time cp /tmp/test.img /mnt/test.img
md5sum -c /tmp/test.md5
umount /dev/sda1
Description
To test the Ethernet ping functionality in Kernel.
Required Hardware
Ethernet Switch / Hub / Router, Ethernet cable.
Test Case 1 (Ping Test)
Make sure the network configuration & connection between Host & Target is established, connected to same switch / router.
Boot the board.
Before the ping test for Ethernet in Linux,we need to set the ip address by using below command on the target board. Make sure both the Target and Host are in the same sub-net
$ ifconfig eth0 192.168.11.20 up
Ping to google by using below command.
$ ping google.com
Expected o/p
root@ruggedboard-imx6ul:~# ifconfig eth0 192.168.11.20 up
root@ruggedboard-imx6ul:~# ifconfig
can0 Link encap:UNSPEC HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
UP RUNNING NOARP MTU:16 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:10
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
Interrupt:34
eth0 Link encap:Ethernet HWaddr 50:2D:F4:24:72:47
inet addr:192.168.11.20 Bcast:192.168.3.255 Mask:255.255.255.0
inet6 addr: 2406:7400:56:4dfb:522d:f4ff:fe24:7247/64 Scope:Global
inet6 addr: fe80::522d:f4ff:fe24:7247/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:13551 errors:0 dropped:1 overruns:0 frame:0
TX packets:547 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:1688904 (1.6 MiB) TX bytes:55344 (54.0 KiB)
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:65536 Metric:1
RX packets:2 errors:0 dropped:0 overruns:0 frame:0
TX packets:2 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:140 (140.0 B) TX bytes:140 (140.0 B)
wwan0 Link encap:Ethernet HWaddr 0E:47:7D:CE:E4:B2
inet6 addr: fe80::c47:7dff:fece:e4b2/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:43 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:9778 (9.5 KiB)
root@ruggedboard-imx6ul:~#
root@ruggedboard-imx6ul:~# ping google.com
PING google.com (142.250.182.14): 56 data bytes
64 bytes from 142.250.182.14: seq=0 ttl=116 time=13.365 ms
64 bytes from 142.250.182.14: seq=1 ttl=116 time=8.825 ms
64 bytes from 142.250.182.14: seq=2 ttl=116 time=8.819 ms
64 bytes from 142.250.182.14: seq=3 ttl=116 time=8.717 ms
64 bytes from 142.250.182.14: seq=4 ttl=116 time=8.660 ms
^C
--- google.com ping statistics ---
10 packets transmitted, 10 packets received, 0% packet loss
round-trip min/avg/max = 8.660/9.215/13.365 ms
root@ruggedboard-imx6ul:~#
Note : Use the working IP address of your LAN. Ping command is used to test net connectivity between two IP based devices.
Description
To test the CAN Device functionality in Kernel.
Required Hardware
RuggedBoard-i.MX6UL
CAN Phy should be mounted on Board.
Test Case 1 (Test with PCAN device)
Boot the board and After booting,check the interface is available or not by giving the below command.
$ ifconfig can0
• To Transmit packets from board to PC
Target side:
$ ip link set can0 down
$ ip link set can0 type can bitrate 50000
$ ip link set can0 up
$ cansend can0 123#1234567890
Host side:
$ sudo ip link set can0 down
$ sudo ip link set can0 type can bitrate 50000
$ sudo ip link set can0 up
$ candump can0
To Transmit packets from PC to Board
Host side :
$ sudo ip link set can0 down
$ sudo ip link set can0 type can bitrate 50000
$ sudo ip link set can0 up
$ sudo cansend can0 123#1232
Target side :
$ ip link set can0 down
$ ip link set can0 type can bitrate 50000
$ ip link set can0 up
$ candump can0
$ can0 123 [2] 12 32
Expected o/p :
To Transmit packets from board to PC
Target side:
root@ruggedboard-imx6ul:~# ifconfig can0
can0 Link encap:UNSPEC HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
UP RUNNING NOARP MTU:16 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:10
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
Interrupt:34
root@ruggedboard-imx6ul:~# ip link set can0 down
root@ruggedboard-imx6ul:~# ip link set can0 type can bitrate 50000
root@ruggedboard-imx6ul:~# ip link set can0 up
root@ruggedboard-imx6ul:~# cansend can0 123#1232555555
root@ruggedboard-imx6ul:~# cansend can0 123#1232555555
root@ruggedboard-imx6ul:~# cansend can0 123#1232555555
root@ruggedboard-imx6ul:~# cansend can0 123#1234567890
root@ruggedboard-imx6ul:~# cansend can0 123#1234567890111213
Host side:
USER@ubuntudesk:~$ sudo ip link set can0 down
USER@ubuntudesk:~$ sudo ip link set can0 type can bitrate 50000
USER@ubuntudesk:~$ sudo ip link set can0 up
USER@ubuntudesk:~$ sudo candump can0
can0 123 [5] 12 32 55 55 55
can0 123 [5] 12 34 56 78 90
can0 123 [8] 12 34 56 78 90 11 12 13
can0 123 [8] 12 34 56 78 90 11 12 13
can0 123 [8] 12 34 56 78 90 11 12 13
To Transmit packets from PC to Board
Host side :
USER@ubuntudesk:~$ sudo ip link set can0 down
USER@ubuntudesk:~$ sudo ip link set can0 type can bitrate 50000
USER@ubuntudesk:~$ sudo ip link set can0 up
USER@ubuntudesk:~$ sudo cansend can0 123#1234567890
USER@ubuntudesk:~$ sudo cansend can0 123#1234567890111213
Target side:
root@ruggedboard-imx6ul:~# ip link set can0 down
root@ruggedboard-imx6ul:~# ip link set can0 type can bitrate 50000
root@ruggedboard-imx6ul:~# ip link set can0 up
root@ruggedboard-imx6ul:~# candump can0
can0 123 [5] 12 32 55 55 55
can0 123 [5] 12 34 56 78 90
can0 123 [8] 12 34 56 78 90 11 12 13
can0 123 [8] 12 34 56 78 90 11 12 13
Test Case 2 (Board to Board)
Take 2 boards and Boot the boards from NAND/MMC.
After booting,check the interface is available or not by giving the below command.
$ ifconfig can0
Test the CAN in 2 Cases.
Case1: Test the CAN through commands.
To Transmit packets from Board1 to Board2
Board1 side:
ip link set can0 down
ip link set can0 type can bitrate 50000
ip link set can0 up
cansend can0 123#1234567890
Board2 side:
ip link set can0 down
ip link set can0 type can bitrate 50000
ip link set can0 up
candump can0
To Transmit packets from Board2 to Board1
Board2 side :
ip link set can0 down
ip link set can0 type can bitrate 50000
ip link set can0 up
cansend can0 123#1234567890
Board1 side :
ip link set can0 down
ip link set can0 type can bitrate 50000
ip link set can0 up
candump can0
Case2: Test the CAN through the application
After booting,run the can send application in board1 and can receive in board2 and vice versa by using like below commands.
./cansend
./canrecv
Expected o/p
Case1 :
To Transmit packets from Board1 to Board2
Board1 side:
root@ruggedboard-imx6ul:~#
root@ruggedboard-imx6ul:~# ifconfig can0
can0 Link encap:UNSPEC HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
UP RUNNING NOARP MTU:16 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:10
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
Interrupt:34
root@ruggedboard-imx6ul:~# ip link set can0 down
root@ruggedboard-imx6ul:~# ip link set can0 type can bitrate 50000
root@ruggedboard-imx6ul:~# ip link set can0 up
root@ruggedboard-imx6ul:~# cansend can0 123#1232555555
root@ruggedboard-imx6ul:~# cansend can0 123#1232555555
root@ruggedboard-imx6ul:~# cansend can0 123#1232555555
root@ruggedboard-imx6ul:~# cansend can0 123#1234567890
root@ruggedboard-imx6ul:~# cansend can0 123#1234567890111213
Board2 side:
root@ruggedboard-imx6ul:~#
root@ruggedboard-imx6ul:~# ifconfig can0
can0 Link encap:UNSPEC HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
UP RUNNING NOARP MTU:16 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:10
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
Interrupt:25
root@ruggedboard-imx6ul:~# ip link set can0 down
root@ruggedboard-imx6ul:~# ip link set can0 type can bitrate 50000
root@ruggedboard-imx6ul:~# ip link set can0 up
root@ruggedboard-imx6ul:~# candump can0
can0 123 [5] 12 32 55 55 55
can0 123 [5] 12 32 55 55 55
can0 123 [5] 12 32 55 55 55
can0 123 [5] 12 34 56 78 90
can0 123 [8] 12 34 56 78 90 11 12 13
can0 123 [8] 12 34 56 78 90 11 12 13
can0 123 [8] 12 34 56 78 90 11 12 13
To Transmit packets from Board2 to Board1
Board2 side :
root@ruggedboard-imx6ul:~#
root@ruggedboard-imx6ul:~# ifconfig can0
can0 Link encap:UNSPEC HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
UP RUNNING NOARP MTU:16 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:10
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
Interrupt:25
root@ruggedboard-imx6ul:~# ip link set can0 down
root@ruggedboard-imx6ul:~# ip link set can0 type can bitrate 50000
root@ruggedboard-imx6ul:~# ip link set can0 up
root@ruggedboard-imx6ul:~# cansend can0 123#1234567890
root@ruggedboard-imx6ul:~# cansend can0 123#1234567890111213
Board1 side :
root@ruggedboard-imx6ul:~#
root@ruggedboard-imx6ul:~# ifconfig can0
can0 Link encap:UNSPEC HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
UP RUNNING NOARP MTU:16 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:10
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
Interrupt:34
root@ruggedboard-imx6ul:~# ip link set can0 down
root@ruggedboard-imx6ul:~# ip link set can0 type can bitrate 50000
root@ruggedboard-imx6ul:~# ip link set can0 up
root@ruggedboard-imx6ul:~# candump can0
can0 123 [5] 12 32 55 55 55
can0 123 [5] 12 32 55 55 55
can0 123 [5] 12 32 55 55 55
can0 123 [5] 12 34 56 78 90
can0 123 [8] 12 34 56 78 90 11 12 13
Case2 :
To Transmit packets from Board1 to Board2
Board1 side :
root@ruggedboard-imx6ul:~# ip link set can0 down
root@ruggedboard-imx6ul:~# ip link set can0 type can bitrate 50000
root@ruggedboard-imx6ul:~# ip link set can0 up
root@ruggedboard-imx6ul:~# ./cans
Can Send Test
can0 at index 2
Wrote 16 bytes
Board2 side :
root@ruggedboard-imx6ul:~# ip link set can0 down
root@ruggedboard-imx6ul:~# ip link set can0 type can bitrate 50000
root@ruggedboard-imx6ul:~# ip link set can0 up
root@ruggedboard-imx6ul:~# ./canr
Can Recieve Test
can0 at index 2
Can frames recieved
<0x123> [2] 11 22
To Transmit packets from Board2 to Board1
Board1 side :
root@ruggedboard-imx6ul:~# ip link set can0 down
root@ruggedboard-imx6ul:~# ip link set can0 type can bitrate 50000
root@ruggedboard-imx6ul:~# ip link set can0 up
root@ruggedboard-imx6ul:~# ./canr
Can Recieve Test
can0 at index 2
Can frames recieved
<0x123> [2] 11 22
Board2 side :
root@ruggedboard-imx6ul:~# ip link set can0 down
root@ruggedboard-imx6ul:~# ip link set can0 type can bitrate 50000
root@ruggedboard-imx6ul:~# ip link set can0 up
root@ruggedboard-imx6ul:~# ./cans
Can Send Test
can0 at index 2
Wrote 16 bytes
Description
To test the digital input pin on the carrier board. Connect a digital input device, such as a switch or button, to the GPIO pin that you want to test.
Required Hardware
RuggedBoard - i.MX6UL
USB cable
Patch card
Step-by-step guide
• Check Carrier board having 4 digital input pins on P5 connector. Fifth pin of P5 connector is ground.
• After completion of board booting, connect the one end of patch card to first pin of P5 connector and other end to input voltage pin.
• Give the below commands to test the digital inputs 1 - To export the gpio.
$ echo 133 > sys/class/gpio/export
2 - To set the in/output of the gpio to the file direction.
$ echo in > /sys/class/gpio/gpio133/direction
3 - To show the value
$ cat /sys/class/gpio/gpio133/value
4 - Remove the patch card and give the below command
$ cat /sys/class/gpio/gpio133/value
• Here GPIO value can be calculated as
VALUE = (gpio_BANK - 1)*32 + GPIO_Value
Note : Gpio calculation will vary for board to board coss-check with boards TRM.
Expected Output
root@ruggedboard-imx6ul:~# echo 133 > /sys/class/gpio/export
root@ruggedboard-imx6ul:~# echo in > /sys/class/gpio/gpio133/direction
root@ruggedboard-imx6ul:~# cat /sys/class/gpio/gpio133/value
1
root@ruggedboard-imx6ul:~# cat /sys/class/gpio/gpio133/value
0
********************************************************************************
root@ruggedboard-imx6ul:~# echo 45 > /sys/class/gpio/export
root@ruggedboard-imx6ul:~# echo in > /sys/class/gpio/gpio45/direction
root@ruggedboard-imx6ul:~# cat /sys/class/gpio/gpio45/value
1
root@ruggedboard-imx6ul:~# cat /sys/class/gpio/gpio45/value
0
********************************************************************************
root@ruggedboard-imx6ul:~# echo 1 > /sys/class/gpio/export
root@ruggedboard-imx6ul:~# echo in > /sys/class/gpio/gpio1/direction
root@ruggedboard-imx6ul:~# cat /sys/class/gpio/gpio1/value
1
root@ruggedboard-imx6ul:~# cat /sys/class/gpio/gpio1/value
0
********************************************************************************
root@ruggedboard-imx6ul:~# echo 1 > /sys/class/gpio/export
root@ruggedboard-imx6ul:~# echo in > /sys/class/gpio/gpio1/direction
root@ruggedboard-imx6ul:~# cat /sys/class/gpio/gpio1/value
1
root@ruggedboard-imx6ul:~# cat /sys/class/gpio/gpio1/value
0
********************************************************************************
Description
To test the digital output pins on carrier board
Required Hardware
RuggedBoard - i.MX6UL
USB cable
External LED
Step-by-step guide
Carrier board having 4 digital out-pins on P6 connector.Please refer the schematic to p6 connector pins.
After booting connect the External LED positive to 2nd pin of P6 connector and other end to Ground.
Please give a below commands and observe the led status.
1 - To export the gpio.
$ echo 14 > /sys/class/gpio/export
2 - To set the in/output of the gpio to the file direction.
$ echo out > /sys/class/gpio/gpio14/direction
3 - To set the gpio value to 1 (off) , indicating the GPIO pin to be set to a active low level.
$ echo 1 > /sys/class/gpio/gpio14/value
4 - To set the gpio value to 0 (on) , indicating the GPIO pin to be set to a active low level.
$ echo 0 > /sys/class/gpio/gpio14/value
• Gpio value can be calculated as
VALUE = (gpio_BANK - 1)*32 + GPIO_Value
Note : Gpio calculation will vary for board to board cosscheck with boards TRM.
Expected Output
root@ruggedboard-imx6ul:~# echo 14 > /sys/class/gpio/export
root@ruggedboard-imx6ul:~# echo out > /sys/class/gpio/gpio14/direction
root@ruggedboard-imx6ul:~# echo 0 > /sys/class/gpio/gpio14/value
root@ruggedboard-imx6ul:~# echo 1 > /sys/class/gpio/gpio14/value
*********************************************************************************
root@ruggedboard-imx6ul:~# echo 15> /sys/class/gpio/export
root@ruggedboard-imx6ul:~# echo out > /sys/class/gpio/gpio15/direction
root@ruggedboard-imx6ul:~# echo 0 > /sys/class/gpio/gpio15/value
root@ruggedboard-imx6ul:~# echo 1 > /sys/class/gpio/gpio15/value
*********************************************************************************
root@ruggedboard-imx6ul:~# echo 12 > /sys/class/gpio/export
root@ruggedboard-imx6ul:~# echo out > /sys/class/gpio/gpio12/direction
root@ruggedboard-imx6ul:~# echo 0 > /sys/class/gpio/gpio12/value
root@ruggedboard-imx6ul:~# echo 1 > /sys/class/gpio/gpio12/value
*********************************************************************************
root@ruggedboard-imx6ul:~# echo 13> /sys/class/gpio/export
root@ruggedboard-imx6ul:~# echo out > /sys/class/gpio/gpio13/direction
root@ruggedboard-imx6ul:~# echo 1 > /sys/class/gpio/gpio13/value
root@ruggedboard-imx6ul:~# echo 0 > /sys/class/gpio/gpio13/value
*********************************************************************************
Description
To test the SD card Port functionality in Kernel with SD card.
To test the SD card Port functionality in Kernel with SD card and read the data from SD card.
To test the SD card Port functionality in Kernel with SD card and write the data to SD card.
Required Hardware
RuggedBoard-i.MX6UL
SD card.
Prerequisite
SD card should be detected.
Test Case 1 (Insert the SD card check the log)
Boot the board from NAND/MMC. After booting or while booting insert the SD card into Board MMC slot, Check the Log file whether node is created or not.
Expected o/p
root@ruggedboard-imx6ul:~# [ 490.928413] mmc0: host does not support reading read-only switch, assuming write-enable
[ 490.942741] mmc0: new high speed SDHC card at address aaaa
[ 490.989133] mmcblk0: mmc0:aaaa SC16G 14.8 GiB
[ 491.071056] mmcblk0: p1 p2 p3
root@ruggedboard-imx6ul:~#
Test Case 2 (Read the data from SD card)
Boot the board from NAND/MMC. After booting or while booting insert the SD card into Board MMC slot, Check the Log file whether node is created or not.
Mount the SD-Card using the mount command.
$ mount /dev/mmcblk0p1 /mnt/
$ cd /mnt/
Expected o/p
root@ruggedboard-imx6ul:~# mount /dev/mmcblk0p1 /mnt/
[ 542.315750] FAT-fs (mmcblk0p1): Volume was not properly unmounted. Some data may be corrupt. Please run fsck.
root@ruggedboard-imx6ul:~# ls
gstreamer-examples@ v4l2_c-examples@
root@ruggedboard-imx6ul:~# cd /mnt/
root@ruggedboard-imx6ul:mnt# ls
Image* imx8mp-phycore-no-spiflash.dtbo*
bootenv.txt* imx8mp-phycore-rpmsg.dtbo*
imx8mp-isi-csi1.dtbo* imx8mp-vm016-csi1-fpdlink.dtbo*
imx8mp-isi-csi2.dtbo* imx8mp-vm016-csi1.dtbo*
imx8mp-isp-csi1.dtbo* imx8mp-vm016-csi2-fpdlink.dtbo*
imx8mp-isp-csi2.dtbo* imx8mp-vm016-csi2.dtbo*
imx8mp-phyboard-pollux-1552.1.dtbo* imx8mp-vm017-csi1-fpdlink.dtbo*
imx8mp-phyboard-pollux-peb-av-010.dtbo* imx8mp-vm017-csi1.dtbo*
imx8mp-phyboard-pollux-peb-av-012.dtbo* imx8mp-vm017-csi2-fpdlink.dtbo*
imx8mp-phyboard-pollux-peb-wlbt-05.dtbo* imx8mp-vm017-csi2.dtbo*
imx8mp-phyboard-pollux-rdk.dtb* oftree*
imx8mp-phycore-no-eth.dtbo* tee.bin*
imx8mp-phycore-no-rtc.dtbo*
root@ruggedboard-imx6ul:mnt#
Test Case 3 (Write the data in SD card)
Boot the board from NAND/MMC. After booting or while booting insert the SD card into Board MMC slot, Check the Log file whether node is created or not.
$ mount /dev/mmcblk0p1 /mnt/
Expected o/p
root@ruggedboard-imx6ul:~# mount /dev/mmcblk0p1 /mnt/
[ 542.315750] FAT-fs (mmcblk0p1): Volume was not properly unmounted. Some data may be corrupt. Please run fsck.
root@ruggedboard-imx6ul:~# ls
gstreamer-examples@ v4l2_c-examples@
root@ruggedboard-imx6ul:~# cd /mnt/
root@ruggedboard-imx6ul:mnt# ls
Image* imx8mp-phycore-no-spiflash.dtbo*
bootenv.txt* imx8mp-phycore-rpmsg.dtbo*
imx8mp-isi-csi1.dtbo* imx8mp-vm016-csi1-fpdlink.dtbo*
imx8mp-isi-csi2.dtbo* imx8mp-vm016-csi1.dtbo*
imx8mp-isp-csi1.dtbo* imx8mp-vm016-csi2-fpdlink.dtbo*
imx8mp-isp-csi2.dtbo* imx8mp-vm016-csi2.dtbo*
imx8mp-phyboard-pollux-1552.1.dtbo* imx8mp-vm017-csi1-fpdlink.dtbo*
imx8mp-phyboard-pollux-peb-av-010.dtbo* imx8mp-vm017-csi1.dtbo*
imx8mp-phyboard-pollux-peb-av-012.dtbo* imx8mp-vm017-csi2-fpdlink.dtbo*
imx8mp-phyboard-pollux-peb-wlbt-05.dtbo* imx8mp-vm017-csi2.dtbo*
imx8mp-phyboard-pollux-rdk.dtb* oftree*
imx8mp-phycore-no-eth.dtbo* tee.bin*
imx8mp-phycore-no-rtc.dtbo*
root@ruggedboard-imx6ul:mnt#
root@ruggedboard-imx6ul:/mnt# vi write.c
root@ruggedboard-imx6ul:mnt# ls
Image* imx8mp-phycore-no-spiflash.dtbo*
bootenv.txt* imx8mp-phycore-rpmsg.dtbo*
imx8mp-isi-csi1.dtbo* imx8mp-vm016-csi1-fpdlink.dtbo*
imx8mp-isi-csi2.dtbo* imx8mp-vm016-csi1.dtbo*
imx8mp-isp-csi1.dtbo* imx8mp-vm016-csi2-fpdlink.dtbo*
imx8mp-isp-csi2.dtbo* imx8mp-vm016-csi2.dtbo*
imx8mp-phyboard-pollux-1552.1.dtbo* imx8mp-vm017-csi1-fpdlink.dtbo*
imx8mp-phyboard-pollux-peb-av-010.dtbo* imx8mp-vm017-csi1.dtbo*
imx8mp-phyboard-pollux-peb-av-012.dtbo* imx8mp-vm017-csi2-fpdlink.dtbo*
imx8mp-phyboard-pollux-peb-wlbt-05.dtbo* imx8mp-vm017-csi2.dtbo*
imx8mp-phyboard-pollux-rdk.dtb* oftree*
imx8mp-phycore-no-eth.dtbo* tee.bin*
imx8mp-phycore-no-rtc.dtbo* write.c*
root@ruggedboard-imx6ul:mnt# ^C
root@ruggedboard-imx6ul:mnt#
root@ruggedboard-imx6ul:mnt# cd
root@ruggedboard-imx6ul:~# umount /mnt/
root@ruggedboard-imx6ul:~#
Description
To test the ADC functionality with Potentio meter
Required Hardware
Rugged Board i.MX6UL
USB cable
Potentiometer
Step-by-step guide
After board booting connect the Potentiometer signal pin to Analog signal pin.
Give the below command to read the digital value of ADC.
$ cat /sys/bus/iio/devices/iio\:device0/in_voltage3_raw
Expected Output
root@ruggedboard-imx6ul:iio# cd /sys/bus/iio/devices/iio\:device0/
root@ruggedboard-imx6ul:iio:device0#
root@ruggedboard-imx6ul:iio:device0#
root@ruggedboard-imx6ul:iio:device0#
root@ruggedboard-imx6ul:iio:device0#
root@ruggedboard-imx6ul:iio:device0# ls
buffer/ in_voltage3_raw
power/ in_voltage_sampling_frequency
scan_elements/ in_voltage_scale
trigger/ name
dev of_node@
in_conversion_mode sampling_frequency_available
in_voltage0_raw subsystem@
in_voltage1_raw uevent
in_voltage2_raw
root@ruggedboard-imx6ul:iio:device0# cat in_voltage3_raw
4095
root@ruggedboard-imx6ul:iio:device0# cat in_voltage3_raw
0
Description
To test the debug console on carrier board.
Required Hardware
RuggedBoad - i.MX6UL
USB cable
Step-by-step guide
Connect the USB cabel to board to PC.
Follow the RB-Quick start guide to set the minicom settings.
Please give the below commands to open the debug console in PC.
$ sudo minicom
Expected Output
barebox 2019.01.0-bsp-yocto-i.mx6ul-pd19.1.0 #1 Fri Mar 10 11:11:44 UTC 2023
Board: Phytec phyCORE-i.MX6 Ultra Lite SOM with NAND
detected i.MX6 UltraLite revision 1.2
i.MX reset reason POR (SRSR: 0x00000001)
i.MX6 UltraLite unique ID: d1e090b62c2fb9d4
mdio_bus: miibus0: probed
eth0: got preset MAC address: 50:2d:f4:24:6f:5b
nand: ONFI flash detected
nand: NAND device: Manufacturer ID: 0x2c, Chip ID: 0xdc (Micron MT29F4G08ABADAH4), 512MiB, page size: 2048, OOB size: 64
Bad block table found at page 262080, version 0x01
Bad block table found at page 262016, version 0x01
imx-usb 2184200.usb@2184200.of: USB EHCI 1.00
imx-esdhc 2190000.usdhc@2190000.of: registered as mmc0
state: New state registered 'state'
state: Using bucket 0@0x00000000
netconsole: registered as netconsole-1
phySOM-i.MX6: Using environment in NAND flash
malloc space: 0x8fe7cec0 -> 0x9fcf9d7f (size 254.5 MiB)
envfs: no envfs (magic mismatch) - envfs never written?
running /env/bin/init...
Hit m for menu or any key to stop autoboot: 0
booting 'nand'
ubi0: attached by fastmap
ubi0: fastmap pool size: 200
ubi0: fastmap WL pool size: 100
ubi0: registering /dev/nand0.root.ubi
ubi0: registering kernel as /dev/nand0.root.ubi.kernel
ubi0: registering oftree as /dev/nand0.root.ubi.oftree
ubi0: registering root as /dev/nand0.root.ubi.root
ubi0: attached mtd0 (name "nand0.root", size 507 MiB) to ubi0
ubi0: PEB size: 131072 bytes (128 KiB), LEB size: 126976 bytes
ubi0: min./max. I/O unit sizes: 2048/2048, sub-page size 2048
ubi0: VID header offset: 2048 (aligned 2048), data offset: 4096
ubi0: good PEBs: 4052, bad PEBs: 4, corrupted PEBs: 0
ubi0: user volume: 3, internal volumes: 1, max. volumes count: 128
ubi0: max/mean erase counter: 3/1, WL threshold: 65536, image sequence number: 2930
ubi0: available PEBs: 0, total reserved PEBs: 4052, PEBs reserved for bad PEB handling: 76
Loading ARM Linux zImage '/dev/nand0.root.ubi.kernel'
Loading devicetree from '/dev/nand0.root.ubi.oftree'
Failed to fixup node in of_fixup_status+0x1/0x28: No such device
Failed to fixup node in of_fixup_status+0x1/0x28: No such device
commandline: consoleblank=0 console=ttymxc0,115200n8 root=ubi0:root ubi.mtd=root rootfstype=ubifs rootwait ro fsck.repair=yes
Starting kernel in secure mode
[ 0.000000] Booting Linux on physical CPU 0x0
[ 0.000000] Linux version 4.14.93-bsp-yocto-i.mx6ul-pd19.1.0 (oe-user@oe-host) (gcc version 7.3.0 (GCC)) #1 SMP Thu Mar 30 10:32:30 UTC 203
[ 0.000000] CPU: ARMv7 Processor [410fc075] revision 5 (ARMv7), cr=10c5387d
[ 0.000000] CPU: div instructions available: patching division code
[ 0.000000] CPU: PIPT / VIPT nonaliasing data cache, VIPT aliasing instruction cache
[ 0.000000] OF: fdt: Machine model: Rugged Board i.MX6 UltraLite
[ 0.000000] Memory policy: Data cache writealloc
[ 0.000000] cma: Reserved 128 MiB at 0x96000000
[ 0.000000] percpu: Embedded 16 pages/cpu @dff91000 s34444 r8192 d22900 u65536
[ 0.000000] Built 1 zonelists, mobility grouping on. Total pages: 130048
[ 0.000000] Kernel command line: consoleblank=0 console=ttymxc0,115200n8 root=ubi0:root ubi.mtd=root rootfstype=ubifs rootwait ro fsck.res
[ 0.000000] PID hash table entries: 2048 (order: 1, 8192 bytes)
[ 0.000000] Dentry cache hash table entries: 65536 (order: 6, 262144 bytes)
[ 0.000000] Inode-cache hash table entries: 32768 (order: 5, 131072 bytes)
[ 0.000000] Memory: 371996K/524288K available (9216K kernel code, 412K rwdata, 3100K rodata, 1024K init, 422K bss, 21220K reserved, 131072)
[ 0.000000] Virtual kernel memory layout:
[ 0.000000] vector : 0xffff0000 - 0xffff1000 ( 4 kB)
[ 0.000000] fixmap : 0xffc00000 - 0xfff00000 (3072 kB)
[ 0.000000] vmalloc : 0xe0800000 - 0xff800000 ( 496 MB)
[ 0.000000] lowmem : 0xc0000000 - 0xe0000000 ( 512 MB)
[ 0.000000] pkmap : 0xbfe00000 - 0xc0000000 ( 2 MB)
[ 0.000000] modules : 0xbf000000 - 0xbfe00000 ( 14 MB)
[ 0.000000] .text : 0xc0008000 - 0xc0a00000 (10208 kB)
[ 0.000000] .init : 0xc0e00000 - 0xc0f00000 (1024 kB)
[ 0.000000] .data : 0xc0f00000 - 0xc0f67320 ( 413 kB)
[ 0.000000] .bss : 0xc0f69000 - 0xc0fd2800 ( 422 kB)
[ 0.000000] SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=1, Nodes=1
[ 0.000000] Hierarchical RCU implementation.
[ 0.000000] RCU event tracing is enabled.
[ 0.000000] RCU restricting CPUs from NR_CPUS=4 to nr_cpu_ids=1.
[ 0.000000] RCU: Adjusting geometry for rcu_fanout_leaf=16, nr_cpu_ids=1
[ 0.000000] NR_IRQS: 16, nr_irqs: 16, preallocated irqs: 16
[ 0.000000] Switching to timer-based delay loop, resolution 41ns
[ 0.000019] sched_clock: 32 bits at 24MHz, resolution 41ns, wraps every 89478484971ns
[ 0.000058] clocksource: mxc_timer1: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[ 0.003040] Console: colour dummy device 80x30
[ 0.003099] Calibrating delay loop (skipped), value calculated using timer frequency.. 48.00 BogoMIPS (lpj=240000)
[ 0.003136] pid_max: default: 32768 minimum: 301
[ 0.003435] Mount-cache hash table entries: 1024 (order: 0, 4096 bytes)
[ 0.003470] Mountpoint-cache hash table entries: 1024 (order: 0, 4096 bytes)
[ 0.004749] CPU: Testing write buffer coherency: ok
[ 0.005333] /cpus/cpu@0 missing clock-frequency property
[ 0.005374] CPU0: thread -1, cpu 0, socket 0, mpidr 80000000
[ 0.006276] Setting up static identity map for 0x80100000 - 0x80100078
[ 0.006608] Hierarchical SRCU implementation.
[ 0.007830] smp: Bringing up secondary CPUs ...
[ 0.007864] smp: Brought up 1 node, 1 CPU
[ 0.007889] SMP: Total of 1 processors activated (48.00 BogoMIPS).
[ 0.007906] CPU: All CPU(s) started in SVC mode.
[ 0.009440] devtmpfs: initialized
[ 0.026309] random: get_random_u32 called from bucket_table_alloc+0x100/0x230 with crng_init=0
[ 0.026747] VFP support v0.3: implementor 41 architecture 2 part 30 variant 7 rev 5
[ 0.027394] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604462750000 ns
[ 0.027442] futex hash table entries: 256 (order: 2, 16384 bytes)
[ 0.037942] pinctrl core: initialized pinctrl subsystem
[ 0.039913] NET: Registered protocol family 16
[ 0.056936] DMA: preallocated 256 KiB pool for atomic coherent allocations
[ 0.059582] CPU identified as i.MX 6UL, silicon rev 1.2
[ 0.071828] vdd3p0: supplied by regulator-dummy
[ 0.073041] cpu: supplied by regulator-dummy
[ 0.074194] vddsoc: supplied by regulator-dummy
[ 0.093620] No ATAGs?
[ 0.093761] hw-breakpoint: found 5 (+1 reserved) breakpoint and 4 watchpoint registers.
[ 0.093798] hw-breakpoint: maximum watchpoint size is 8 bytes.
[ 0.097805] imx6ul-pinctrl 20e0000.iomuxc: Invalid fsl,pins or pins property in node /soc/aips-bus@2000000/iomuxc@20e0000/wlangrp
[ 0.097897] imx6ul-pinctrl 20e0000.iomuxc: initialized IMX pinctrl driver
[ 0.141950] mxs-dma 1804000.dma-apbh: initialized
[ 0.148418] vgaarb: loaded
[ 0.149426] SCSI subsystem initialized
[ 0.150485] usbcore: registered new interface driver usbfs
[ 0.150633] usbcore: registered new interface driver hub
[ 0.150845] usbcore: registered new device driver usb
[ 0.153830] i2c i2c-0: IMX I2C adapter registered
[ 0.153878] i2c i2c-0: can't use DMA, using PIO instead.
[ 0.155355] i2c i2c-1: IMX I2C adapter registered
[ 0.155403] i2c i2c-1: can't use DMA, using PIO instead.
[ 0.155791] media: Linux media interface: v0.10
[ 0.155924] Linux video capture interface: v2.00
[ 0.156064] pps_core: LinuxPPS API ver. 1 registered
[ 0.156084] pps_core: Software ver. 5.3.6 - Copyright 2005-2007 Rodolfo Giometti <giometti@linux.it>
[ 0.156135] PTP clock support registered
[ 0.156811] Advanced Linux Sound Architecture Driver Initialized.
[ 0.158474] Bluetooth: Core ver 2.22
[ 0.158593] NET: Registered protocol family 31
[ 0.158615] Bluetooth: HCI device and connection manager initialized
[ 0.158653] Bluetooth: HCI socket layer initialized
[ 0.158681] Bluetooth: L2CAP socket layer initialized
[ 0.158750] Bluetooth: SCO socket layer initialized
[ 0.161250] clocksource: Switched to clocksource mxc_timer1
[ 0.161625] VFS: Disk quotas dquot_6.6.0
[ 0.161784] VFS: Dquot-cache hash table entries: 1024 (order 0, 4096 bytes)
[ 0.182617] NET: Registered protocol family 2
[ 0.184024] TCP established hash table entries: 4096 (order: 2, 16384 bytes)
[ 0.184154] TCP bind hash table entries: 4096 (order: 3, 32768 bytes)
[ 0.184313] TCP: Hash tables configured (established 4096 bind 4096)
[ 0.184519] UDP hash table entries: 256 (order: 1, 8192 bytes)
[ 0.184582] UDP-Lite hash table entries: 256 (order: 1, 8192 bytes)
[ 0.184918] NET: Registered protocol family 1
[ 0.185837] RPC: Registered named UNIX socket transport module.
[ 0.185867] RPC: Registered udp transport module.
[ 0.185882] RPC: Registered tcp transport module.
[ 0.185899] RPC: Registered tcp NFSv4.1 backchannel transport module.
[ 0.190775] workingset: timestamp_bits=30 max_order=17 bucket_order=0
[ 0.201027] squashfs: version 4.0 (2009/01/31) Phillip Lougher
[ 0.202699] NFS: Registering the id_resolver key type
[ 0.202778] Key type id_resolver registered
[ 0.202798] Key type id_legacy registered
[ 0.202911] jffs2: version 2.2. (NAND) �© 2001-2006 Red Hat, Inc.
[ 0.204011] fuse init (API version 7.26)
[ 0.216169] NET: Registered protocol family 38
[ 0.216563] io scheduler noop registered
[ 0.216590] io scheduler deadline registered
[ 0.216956] io scheduler cfq registered (default)
[ 0.216981] io scheduler mq-deadline registered
[ 0.216999] io scheduler kyber registered
[ 0.224485] mxsfb 21c8000.lcdif: 21c8000.lcdif supply lcd not found, using dummy regulator
[ 0.247819] Console: switching to colour frame buffer device 100x30
[ 0.263121] mxsfb 21c8000.lcdif: initialized
[ 0.266500] imx-sdma 20ec000.sdma: loaded firmware 3.3
[ 0.276041] 2020000.serial: ttymxc0 at MMIO 0x2020000 (irq = 22, base_baud = 5000000) is a IMX
[ 0.979081] console [ttymxc0] enabled
[ 0.984718] 21e8000.serial: ttymxc1 at MMIO 0x21e8000 (irq = 61, base_baud = 5000000) is a IMX
[ 0.994847] 21ec000.serial: ttymxc2 at MMIO 0x21ec000 (irq = 62, base_baud = 5000000) is a IMX
[ 1.005048] 21f4000.serial: ttymxc4 at MMIO 0x21f4000 (irq = 63, base_baud = 5000000) is a IMX
[ 1.015354] 21fc000.serial: ttymxc5 at MMIO 0x21fc000 (irq = 64, base_baud = 5000000) is a IMX
[ 1.057750] brd: module loaded
[ 1.077839] loop: module loaded
[ 1.082871] at24 0-0052: 4096 byte 24c32 EEPROM, writable, 1 bytes/write
[ 1.100359] random: fast init done
[ 1.107171] nand: device found, Manufacturer ID: 0x2c, Chip ID: 0xdc
[ 1.113616] nand: Micron MT29F4G08ABADAH4
[ 1.117656] nand: 512 MiB, SLC, erase size: 128 KiB, page size: 2048, OOB size: 64
[ 1.126101] gpmi-nand 1806000.gpmi-nand: enable the asynchronous EDO mode 5
[ 1.134271] Bad block table found at page 262080, version 0x01
[ 1.140543] Bad block table found at page 262016, version 0x01
[ 1.147213] 3 ofpart partitions found on MTD device gpmi-nand
[ 1.153056] Creating 3 MTD partitions on "gpmi-nand":
[ 1.158146] 0x000000000000-0x000000400000 : "barebox"
[ 1.166337] 0x000000400000-0x000000500000 : "barebox-environment"
[ 1.174825] 0x000000500000-0x000020000000 : "root"
[ 1.289273] gpmi-nand 1806000.gpmi-nand: driver registered.
[ 1.301093] spi_imx 2008000.ecspi: probed
[ 1.308675] spi_imx 200c000.ecspi: probed
[ 1.314648] libphy: Fixed MDIO Bus: probed
[ 1.319840] CAN device driver interface
[ 1.325800] flexcan 2090000.flexcan: device registered (reg_base=e0a28000, irq=24)
[ 1.335454] fec 20b4000.ethernet: 20b4000.ethernet supply phy not found, using dummy regulator
[ 1.345250] pps pps0: new PPS source ptp0
[ 1.378937] libphy: fec_enet_mii_bus: probed
[ 1.385038] fec 20b4000.ethernet eth1: registered PHC device 0
[ 1.393465] fec 2188000.ethernet: 2188000.ethernet supply phy not found, using dummy regulator
[ 1.403340] pps pps1: new PPS source ptp1
[ 1.408831] libphy: fec_enet_mii_bus: probed
[ 1.415811] fec 2188000.ethernet eth0: registered PHC device 1
[ 1.423364] PPP generic driver version 2.4.2
[ 1.428114] PPP BSD Compression module registered
[ 1.432992] PPP Deflate Compression module registered
[ 1.438157] PPP MPPE Compression module registered
[ 1.443104] NET: Registered protocol family 24
[ 1.447826] usbcore: registered new interface driver asix
[ 1.453553] usbcore: registered new interface driver ax88179_178a
[ 1.459764] usbcore: registered new interface driver cdc_ether
[ 1.465871] usbcore: registered new interface driver net1080
[ 1.471713] usbcore: registered new interface driver rndis_host
[ 1.477734] usbcore: registered new interface driver cdc_subset
[ 1.483816] usbcore: registered new interface driver zaurus
[ 1.489536] usbcore: registered new interface driver cdc_ncm
[ 1.495502] usbcore: registered new interface driver qmi_wwan
[ 1.501376] ehci_hcd: USB 2.0 'Enhanced' Host Controller (EHCI) Driver
[ 1.507931] ehci-pci: EHCI PCI platform driver