When I capture with v4l2 using the camera driver that I ported from the imx219 driver, the kernel displays an error message:
4250.631050] [RCE] vi5_hwinit: firmware CL2018101701 protocol version 2.2
[ 4253.263027] tegra194-vi5 15c10000.vi: no reply from camera processor
[ 4253.263209] tegra194-vi5 15c10000.vi: uncorr_err: request timed out after 2500 ms
[ 4253.263349] tegra194-vi5 15c10000.vi: err_rec: attempting to reset the capture channel
[ 4253.266731] Unable to handle kernel NULL pointer dereference at virtual address 00000010
[ 4253.266928] Mem abort info:
[ 4253.267072] ESR = 0x96000005
[ 4253.267153] Exception class = DABT (current EL), IL = 32 bits
[ 4253.267258] SET = 0, FnV = 0
[ 4253.267318] EA = 0, S1PTW = 0
[ 4253.267408] Data abort info:
[ 4253.267467] ISV = 0, ISS = 0x00000005
[ 4253.267541] CM = 0, WnR = 0
[ 4253.267605] user pgtable: 4k pages, 39-bit VAs, pgd = ffffffc1919a6000
[ 4253.267718] [0000000000000010] *pgd=0000000000000000, *pud=0000000000000000
[ 4253.267874] Internal error: Oops: 96000005 [#1] PREEMPT SMP
[ 4253.267979] Modules linked in: fuse xt_conntrack ipt_MASQUERADE nf_nat_masquerade_ipv4 nf_conntrack_netlink nfnetlink iwlmvm mac80211 xt_addrtype iptable_filter iptable_nat nf_conntrack_ipv4 nf_defrag_ipv4 nf_nat_ipv4 nf_nat nf_conntrack br_netfilter bnep zram overlay btusb btrtl btbcm btintel userspace_alert iwlwifi cfg80211 nvgpu ip_tables x_tables
[ 4253.282070] CPU: 0 PID: 21403 Comm: vi-output, mvfp Not tainted 4.9.253-tegra #9
[ 4253.289316] Hardware name: NVIDIA Jetson Xavier NX Developer Kit (DT)
[ 4253.295877] task: ffffffc1f4da0000 task.stack: ffffffc12afe4000
[ 4253.301924] PC is at _raw_write_lock+0x30/0x58
[ 4253.306118] LR is at destroy_buffer_table+0x40/0xd8
[ 4253.311010] pc : [<ffffff8008f6be00>] lr : [<ffffff8008b4c990>] pstate: 20c00045
[ 4253.318360] sp : ffffffc12afe7c70
[ 4253.321342] x29: ffffffc12afe7c70 x28: 0000000000000000
[ 4253.326683] x27: 0000000000000000 x26: 0000000000000000
[ 4253.332708] x25: 0000000000000010 x24: 0000000000000098
[ 4253.337869] x23: 0000000000000018 x22: ffffff8009087230
[ 4253.342958] x21: 0000000000000000 x20: ffffffc1d5917380
[ 4253.348381] x19: 0000000000000010 x18: 00000000000004d4
[ 4253.354230] x17: 0000000000000002 x16: 0000000000000003
[ 4253.360006] x15: 00000000000001d4 x14: 0000000000006195
[ 4253.365445] x13: 0000000000006a20 x12: 0000000000000400
[ 4253.371133] x11: 0000000000000400 x10: 0000000000000000
[ 4253.377069] x9 : ffffffc12afe7a80 x8 : fffffffffffffffe
[ 4253.382843] x7 : ffffffc198c048c0 x6 : ffffffc1f4da0000
[ 4253.388109] x5 : ffffffc198c04cc0 x4 : ffffffc1ffd12160
[ 4253.393445] x3 : 0000000000000000 x2 : ffffffc198c04e80
[ 4253.399029] x1 : 0000000000000000 x0 : 0000000080000000
[ 4253.405527] Process vi-output, mvfp (pid: 21403, stack limit = 0xffffffc12afe4000)
[ 4253.412687] Call trace:
[ 4253.415319] [<ffffff8008f6be00>] _raw_write_lock+0x30/0x58
[ 4253.420130] [<ffffff8008b4c990>] destroy_buffer_table+0x40/0xd8
[ 4253.425732] [<ffffff8008b3ec84>] vi_capture_shutdown+0xd4/0x130
[ 4253.431328] [<ffffff8008b3f2dc>] vi_channel_close_ex+0x34/0x88
[ 4253.437188] [<ffffff8008b407e8>] vi5_channel_error_recover+0x48/0x1c8
[ 4253.442879] [<ffffff8008b35910>] tegra_channel_error_recover+0x58/0x90
[ 4253.449010] [<ffffff8008b410a8>] tegra_channel_kthread_capture_dequeue+0xf8/0x1c0
[ 4253.455920] [<ffffff80080db09c>] kthread+0xec/0xf0
[ 4253.460732] [<ffffff80080838a0>] ret_from_fork+0x10/0x30
[ 4253.466066] ---[ end trace 92bec307885cb670 ]---
[ 4253.484333] note: vi-output, mvfp[21403] exited with preempt_count 1
[ 4256.591307] FAN rising trip_level:1 cur_temp:46000 trip_temps[2]:60000
[ 4361.871110] FAN cooling trip_level:0 cur_temp:37800 trip_temps[1]:46000
[ 4519.790901] FAN rising trip_level:1 cur_temp:46000 trip_temps[2]:60000
[ 4629.550883] FAN cooling trip_level:0 cur_temp:37800 trip_temps[1]:46000
[ 4791.950637] FAN rising trip_level:1 cur_temp:46100 trip_temps[2]:60000
[ 4906.190272] FAN cooling trip_level:0 cur_temp:37800 trip_temps[1]:46000
[ 5074.190137] FAN rising trip_level:1 cur_temp:46100 trip_temps[2]:60000
[ 5183.950118] FAN cooling trip_level:0 cur_temp:37800 trip_temps[1]:46000
The results from using media-ctl for verification are as follows:
nx@nvidia:~$ sudo media-ctl -p -d /dev/media0
[sudo] password for nx:
Media controller API version 0.1.0
Media device information
------------------------
driver tegra194-vi5
model NVIDIA Tegra Video Input Device
serial
bus info
hw revision 0x3
driver version 0.0.0
Device topology
- entity 1: mvfpga 9-0010 (1 pad, 1 link)
type V4L2 subdev subtype Sensor flags 0
device node name /dev/v4l-subdev0
pad0: Source
[fmt:YUYV8_1X16/1920x1080 field:none colorspace:srgb]
-> "15a00000.nvcsi--5":0 [ENABLED]
- entity 3: 15a00000.nvcsi--5 (2 pads, 2 links)
type V4L2 subdev subtype Unknown flags 0
device node name /dev/v4l-subdev1
pad0: Sink
<- "mvfpga 9-0010":0 [ENABLED]
pad1: Source
-> "vi-output, mvfpga 9-0010":0 [ENABLED]
- entity 6: vi-output, mvfpga 9-0010 (1 pad, 1 link)
type Node subtype V4L flags 0
device node name /dev/video0
pad0: Sink
<- "15a00000.nvcsi--5":1 [ENABLED]
- entity 18: mvfpga 9-0011 (1 pad, 1 link)
type V4L2 subdev subtype Sensor flags 0
device node name /dev/v4l-subdev2
pad0: Source
[fmt:YUYV8_1X16/1920x1080 field:none colorspace:srgb]
-> "15a00000.nvcsi--4":0 [ENABLED]
- entity 20: 15a00000.nvcsi--4 (2 pads, 2 links)
type V4L2 subdev subtype Unknown flags 0
device node name /dev/v4l-subdev3
pad0: Sink
<- "mvfpga 9-0011":0 [ENABLED]
pad1: Source
-> "vi-output, mvfpga 9-0011":0 [ENABLED]
- entity 23: vi-output, mvfpga 9-0011 (1 pad, 1 link)
type Node subtype V4L flags 0
device node name /dev/video1
pad0: Sink
<- "15a00000.nvcsi--4":1 [ENABLED]
- entity 35: mvfpga 9-0012 (1 pad, 1 link)
type V4L2 subdev subtype Sensor flags 0
device node name /dev/v4l-subdev4
pad0: Source
[fmt:YUYV8_1X16/1920x1080 field:none colorspace:srgb]
-> "15a00000.nvcsi--3":0 [ENABLED]
- entity 37: 15a00000.nvcsi--3 (2 pads, 2 links)
type V4L2 subdev subtype Unknown flags 0
device node name /dev/v4l-subdev5
pad0: Sink
<- "mvfpga 9-0012":0 [ENABLED]
pad1: Source
-> "vi-output, mvfpga 9-0012":0 [ENABLED]
- entity 40: vi-output, mvfpga 9-0012 (1 pad, 1 link)
type Node subtype V4L flags 0
device node name /dev/video2
pad0: Sink
<- "15a00000.nvcsi--3":1 [ENABLED]
- entity 52: mvfpga 9-0013 (1 pad, 1 link)
type V4L2 subdev subtype Sensor flags 0
device node name /dev/v4l-subdev6
pad0: Source
[fmt:YUYV8_1X16/1920x1080 field:none colorspace:srgb]
-> "15a00000.nvcsi--2":0 [ENABLED]
- entity 54: 15a00000.nvcsi--2 (2 pads, 2 links)
type V4L2 subdev subtype Unknown flags 0
device node name /dev/v4l-subdev7
pad0: Sink
<- "mvfpga 9-0013":0 [ENABLED]
pad1: Source
-> "vi-output, mvfpga 9-0013":0 [ENABLED]
- entity 57: vi-output, mvfpga 9-0013 (1 pad, 1 link)
type Node subtype V4L flags 0
device node name /dev/video3
pad0: Sink
<- "15a00000.nvcsi--2":1 [ENABLED]
- entity 69: mvfpga 9-0014 (1 pad, 1 link)
type V4L2 subdev subtype Sensor flags 0
device node name /dev/v4l-subdev8
pad0: Source
[fmt:YUYV8_1X16/1920x1080 field:none colorspace:srgb]
-> "15a00000.nvcsi--1":0 [ENABLED]
- entity 71: 15a00000.nvcsi--1 (2 pads, 2 links)
type V4L2 subdev subtype Unknown flags 0
device node name /dev/v4l-subdev9
pad0: Sink
<- "mvfpga 9-0014":0 [ENABLED]
pad1: Source
-> "vi-output, mvfpga 9-0014":0 [ENABLED]
- entity 74: vi-output, mvfpga 9-0014 (1 pad, 1 link)
type Node subtype V4L flags 0
device node name /dev/video4
pad0: Sink
<- "15a00000.nvcsi--1":1 [ENABLED]
My camera does not require I2C for configuration. The driver only needs to receive data from the CSI. Where should I address this issue? Thank you!