kan_harada
2024年12月11日 14時12分
Armadillo X2にシキノハイテックのKBCR-S51MM(150万画素モノクロプログレッシブカメラ)を接続しようとしています。
CON10(MIPI)にカメラを接続してみてますが、CON10/11番ピンがこのカメラのPowerEnable信号となっているため、CSI1_GPIO0_3V3をHIGHにする必要がありそうなのですが、この信号線のArmadilloのGPIO番号/IO番号が知りたいです。何を見れば良いでしょうか?
※ちなみに現状、ここのピンに電圧はでていません。
参考にしているデバイスツリーはarmadillo_iotg_g4-con10-ox01f10.dtsです。これからarmadillo_iotg_g4-con10-ox01h1b.dtsを作って使用しようとしてます。この中は以下のようになっていて、カメラのI2Cアドレスが0x20らしいのでそこを書き換えているのみです。
// SPDX-License-Identifier: (GPL-2.0 OR MIT)
/*
* Copyright (C) 2021 Atmark Techno, Inc. All Rights Reserved.
*/
/dts-v1/;
/plugin/;
#include
#include
#include "imx8mp-pinfunc.h"
&i2c2 {
#address-cells = <1>;
#size-cells = <0>;
og01h1b_cam0: rbpcv2_og01h1b@30 {
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_og01h1b_pwn>;
compatible = "brcm,bcm2835";
/* I2C device address */
reg = <0x20>; /* カメラアドレスに書き換えで合ってる? */
pwdn-gpios = <&gpio3 6 GPIO_ACTIVE_HIGH>; /* これがCON10/#11ピン? */
clocks = <&clk IMX8MP_CLK_IPP_DO_CLKO2>;
clock-names = "csi_mclk";
assigned-clocks = <&clk IMX8MP_CLK_IPP_DO_CLKO2>;
assigned-clock-parents = <&clk IMX8MP_CLK_24M>;
assigned-clock-rates = <24000000>;
csi_id = <0>;
mclk = <24000000>;
mclk_source = <0>;
mipi_csi;
status = "okay";
port {
og01h1b_mipi_0_ep: endpoint {
remote-endpoint = <&mipi_csi0_ep>;
data-lanes = <1>;
clock-lanes = <0>;
max-pixel-frequency = /bits/ 64 <224000000>;
};
};
};
};
&iomuxc {
pinctrl_og01h1b_pwn: og01h1b_pwn_grp { /* GPIOピンのMUX設定? */
fsl,pins = <
MX8MP_IOMUXC_NAND_DATA00__GPIO3_IO06 0x40000100
>;
};
};
&mipi_csi_0 {
#address-cells = <1>;
#size-cells = <0>;
status = "okay";
port@0 {
reg = <0>;
mipi_csi0_ep: endpoint {
remote-endpoint = <&og01h1b_mipi_0_ep>;
data-lanes = <1>;
csis-hs-settle = <16>;
};
};
};
&cameradev {
status = "okay";
};
&isi_0 {
status = "okay";
cap_device {
status = "okay";
};
m2m_device {
status = "okay";
};
};
&isp_0 {
status = "okay";
};
&dewarp {
status = "okay";
};
コメント
kan_harada
下山様 デバイスツリー, ドライバーのソースまで頂き、ありがとうございます。
早速、コンパイルしてトライしていますが、まだうまく動いていません(FPCの逆差しをやってしまったので、Armadillo, カメラのいずれかが故障している可能性もあります)
device treeはarch/arm64/boot/dts/freescale/armadillo_iotg_g4-con10-thcv24xa-ox01f10.dtboを/bootにコピーしてoverlay.txtで起動時に読込んでいます。i2cdetectでサーチしてみたところ、昨日までできていなかった箇所にUUとでているので、設定はできてるのでは・・と思っています。
# i2cdetect -y 1
0 1 2 3 4 5 6 7 8 9 a b c d e f
00: -- -- -- -- -- -- -- --
10: UU -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
20: -- -- -- -- -- -- -- -- -- -- -- -- UU -- -- --
30: -- -- UU -- -- -- -- -- -- -- -- -- -- -- -- --
40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
50: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
70: -- -- -- -- -- -- -- --
I2Cドライバはカーネルモジュールとしてコンパイルして/lib/moules/以下に配置しています。depmodを実行しておいたので、X2起動時に自動的に読込まれていることは確認しました。以下がdmesgの該当箇所です。
[ 2.375520] og01h1b: module verification failed: signature and/or required key missing - tainting kernel
[ 2.376783] og01h1b_probe:devm_kzalloc
[ 2.376795] og01h1b_probe:Initialize subdev
[ 2.376856] og01h1b 1-0010: supply avdd not found, using dummy regulator
[ 2.376951] og01h1b 1-0010: supply dovdd not found, using dummy regulator
[ 2.376965] og01h1b 1-0010: supply dvdd not found, using dummy regulator
[ 2.492079] og01h1b_probe:og01h1b_detect
[ 2.492115] og01h1b_probe:og01h1b_init_controls
[ 2.492149] og01h1b_probe:pm_runtime_set_active
"supply avdd not found, using dummy regulator"というところが気になりますが、これで良いのでしょうか?
at_shota.shimoyama
下山です。
> i2cdetectでサーチしてみたところ、昨日までできていなかった箇所にUUとでているので、設定はできてるのでは・・と思っています。
こちらでも同様の結果になりました。
> [ 2.375520] og01h1b: module verification failed: signature and/or required key missing - tainting kernel
> [ 2.376783] og01h1b_probe:devm_kzalloc
> [ 2.376795] og01h1b_probe:Initialize subdev
> [ 2.376856] og01h1b 1-0010: supply avdd not found, using dummy regulator
> [ 2.376951] og01h1b 1-0010: supply dovdd not found, using dummy regulator
> [ 2.376965] og01h1b 1-0010: supply dvdd not found, using dummy regulator
> [ 2.492079] og01h1b_probe:og01h1b_detect
> [ 2.492115] og01h1b_probe:og01h1b_init_controls
> [ 2.492149] og01h1b_probe:pm_runtime_set_active
>
> "supply avdd not found, using dummy regulator"というところが気になりますが、これで良いのでしょうか?
はい、大丈夫です。
> 早速、コンパイルしてトライしていますが、まだうまく動いていません(FPCの逆差しをやってしまったので、Armadillo, カメラのいずれかが故障している可能性もあります)
うまく動いていないというのは具体的にどういったことかお伺いしてもよろしいでしょうか?
また、 v4l2-ctl --list-device
の実行結果で以下のように/dev/video2を確認できるでしょうか?
root@5a21e06ad210:/# v4l2-ctl --list-device mxc-isi-cap (platform:32e00000.isi:cap_devic): /dev/video2 Failed to open /dev/video0: Device or resource busy
よろしくお願いします。
kan_harada
~ # v4l2-ctl --list-device
mxc-isi-m2m (platform:32e00000.isi:m2m_devic):
/dev/video2
Failed to open /dev/video0: Device or resource busy
~ # v4l2-ctl -d /dev/video2 -V
Format Video Capture Multiplanar:
Width/Height : 4096/8192
Pixel Format : 'RGBP' (16-bit RGB 5-6-5)
Field : None
Number of planes : 1
Flags :
Colorspace : sRGB
Transfer Function : sRGB
YCbCr/HSV Encoding: ITU-R 601
Quantization : Full Range
Plane 0 :
Bytes per Line : 8192
Size Image : 67108864
という状態で/dev/video2は認識できていますが、そこのカメラ情報がおかしいです。また、電源が供給されていないようで、カメラの3.3Vは供給されていません。
kan_harada
追加で、以下のような状態です。やはりカメラが壊れてるのかもしれません。現在、追加でカメラを発注しているので、そちらで確認しましょう。
# gst-launch-1.0 v4l2src device=/dev/video2
パイプラインを一時停止 (PAUSED) にしています...
ERROR: from element /GstPipeline:pipeline0/GstV4l2Src:v4l2src0: Device '/dev/video2' is not a capture device.
追加のデバッグ情報:
../sys/v4l2/v4l2_calls.c(629): gst_v4l2_open (): /GstPipeline:pipeline0/GstV4l2Src:v4l2src0:
Capabilities: 0x4204000
ERROR: pipeline doesn't want to preroll.
Failed to set pipeline to PAUSED.
Setting pipeline to NULL ...
Freeing pipeline ...
at_shota.shimoyama
下山です。
/dev以下には次のようにvideo3のデバイスファイルも見えていますでしょうか?
armadillo:~# ls /dev/video* /dev/video0 /dev/video1 /dev/video2 /dev/video3 armadillo:~# v4l2-ctl --list-device (): /dev/v4l-subdev0 mxc-isi-cap (platform:32e00000.isi:cap_devic): /dev/video2 mxc-isi-m2m (platform:32e00000.isi:m2m_devic): /dev/video3 FSL Capture Media Device (platform:mxc-md): /dev/media0 Failed to open /dev/video0: Resource busy
こちらでは/dev/video2がmxc-isi-capに対応しているのですが、
もしかしたらkan_harada様の個体では/dev/video3の方に対応しているかもしれません。
> また、電源が供給されていないようで、カメラの3.3Vは供給されていません。
電源は常時供給されているわけではなく、カメラを使用するタイミングのみ3.3Vが供給されますので、
gstreamerのコマンドを実行していないときに電源が供給されていないということであれば正常です。
> 追加で、以下のような状態です。やはりカメラが壊れてるのかもしれません。現在、追加でカメラを発注しているので、そちらで確認しましょう。
承知しました。
よろしくお願いします。
kan_harada
新しいカメラ基板と変換基板が届いたので早速トライしてみましたが、結果は変わりませんでした。まずはFPCの接続確認のため写真を添付します。この状態でカメラ基板のGNDとArmadilloのGNDは導通があるので接続的には問題ないと考えています。
Armadillo X2も別の基板に入れ替えてみましたが、それも同じ結果でした。この基板ではKBCR-S08MMが問題なく動いています。
こちらの環境でv4l2の状態は以下のようになっていて、カメラは/dev/video2に接続されているようです。
armadillo:~# ls /dev/video*
/dev/video0 /dev/video1 /dev/video2
# v4l2-ctl --list-device
mxc-isi-m2m (platform:32e00000.isi:m2m_devic):
/dev/video2
Failed to open /dev/video0: Device or resource busy
ファイル | ファイルの説明 |
---|---|
FPC接続.pdf |
at_shota.shimoyama
下山です。
> 新しいカメラ基板と変換基板が届いたので早速トライしてみましたが、結果は変わりませんでした。まずはFPCの接続確認のため写真を添付します。この状態でカメラ基板のGNDとArmadilloのGNDは導通があるので接続的には問題ないと考えています。
添付画像を拝見いたしましたが、私もピンの接続方法に問題は無いように見えます。
> Armadillo X2も別の基板に入れ替えてみましたが、それも同じ結果でした。この基板ではKBCR-S08MMが問題なく動いています。
> こちらの環境でv4l2の状態は以下のようになっていて、カメラは/dev/video2に接続されているようです。
>
> armadillo:~# ls /dev/video*
> /dev/video0 /dev/video1 /dev/video2
>
> # v4l2-ctl --list-device
> mxc-isi-m2m (platform:32e00000.isi:m2m_devic):
> /dev/video2
>
> Failed to open /dev/video0: Device or resource busy
>
mxc-isi-cap
が表示されないのはおかしいですね。
ドライバをカーネルモジュールとしてコンパイルするのではなく、
https://manual.atmark-techno.com/armadillo-x2/armadillo-x2_product_manu…
の「5.ビルド」でカーネル全体をビルドし、
「6.インストール」の「swupdate でインストールする」でLinuxカーネルの更新をArmadilloに適用する方法を行ってみていただけますでしょうか?
(私の方ではこの手順で行っています)
また、I2Cドライバをカーネルモジュールとしてコンパイルする具体的な手順を教えていただけますでしょうか?
こちらで再現できるかどうか確認してみます。
よろしくお願いします。
kan_harada
kernel moduleではなく、カーネル組込みの件は承知しました。今週は出張にで出ているので、戻り次第やってみます。
モジュールコンパイルは以下の手順でやりました。
1) .configの以下の行を'm'に変更
CONFIG_VIDEO_OG01H1B=m
2) make ARCH=arm64 CROSS_COMPILE=aarch64-linux-gnu- modules dtbs
でカーネルモジュールとデバイスツリーをクロスコンパイル
3) できあがったdrivers/media/i2c/og01h1b.koをABOSの/lib/modules/kernel/...以下にコピーしてdepmod -aを実行後、コピーしたファイル, depmodの結果変更されたファイルに対してpersist_fileを実行。同様に/boot/のoverlay.txtも変更し、コンパイルしたarmadillo_iotg_g4-customize.dtboを/bootにコピー後persist_fileを実行して保存
kan_harada
kernelモジュールをやめてドライバをカーネル組込みにすることでストリーミングできました。その時の画面とhtopでCPU負荷をみた様子のスクリーンショットを添付します。やっとここまで来ました。ありがとうございます。
しかし、みていただいてわかるように、X Windowを動かしているためかCPU負荷が重過ぎで、この後別のソフトウェア(ROS他)を動かすことを考えると何か工夫が必要です。
例えば、フレームレートを1fpsに設定することは可能でしょうか?
ファイル | ファイルの説明 |
---|---|
スクリーンショット 2024-12-25 19.07.04.png | |
スクリーンショット 2024-12-25 19.06.43.png |
at_shota.shimoyama
下山です。
> kernelモジュールをやめてドライバをカーネル組込みにすることでストリーミングできました。その時の画面とhtopでCPU負荷をみた様子のスクリーンショットを添付します。やっとここまで来ました。ありがとうございます。
それは何よりです。
> しかし、みていただいてわかるように、X Windowを動かしているためかCPU負荷が重過ぎで、この後別のソフトウェア(ROS他)を動かすことを考えると何か工夫が必要です。
> 例えば、フレームレートを1fpsに設定することは可能でしょうか?
カメラ側のフォーマットであるGRAY8がディスプレイ側で対応していないため、videoconvertを間に入れてディスプレイ側で対応しているフォーマットに変換する必要があるのですが、このvideoconvertの処理がボトルネックのようです。
ですので、最適解ではないかもしれませんが、videorateを使用してvideoconvertに渡すフレームの数を減らすといった工夫はできます。
(max-rateの部分でフレームレートを指定します。↓の例ではフレームレートを1fpsに設定しています。)
gst-launch-1.0 v4l2src device=/dev/video2 ! video/x-raw,format=GRAY8,width=1440,height=1080,framerate=30/1 ! videorate drop-only=true max-rate=1 ! videoconvert n-threads=4 ! autovideosink sync=false
よろしくお願いします。
kan_harada
ありがとうございます。ひとまず1fps設定で負荷を落とすことはできました。(添付参照)
それと、armadillo側でのカメラ認識ですが、カーネルもジュールをやめたところ、以下のように変化しました。
# v4l2-ctl --list-device
():
/dev/v4l-subdev0
FSL Capture Media Device (platform:mxc-md):
/dev/media0
Failed to open /dev/video0: Device or resource busy
~ # v4l2-ctl --list-device
():
/dev/v4l-subdev0
mxc-isi-cap (platform:32e00000.isi:cap_devic):
/dev/video2
mxc-isi-m2m (platform:32e00000.isi:m2m_devic):
/dev/video3
FSL Capture Media Device (platform:mxc-md):
/dev/media0
Failed to open /dev/video0: Device or resource busy
/dev/video3で開こうとすると先日までと同じ状態となります。カメラとしては/dev/video2が対象になるようです。
ファイル | ファイルの説明 |
---|---|
モノクロカメラ.png |
kan_harada
at_shota.shimoyama
2024年12月11日 17時53分
下山です。
> CON10(MIPI)にカメラを接続してみてますが、CON10/11番ピンがこのカメラのPowerEnable信号となっているため、CSI1_GPIO0_3V3をHIGHにする必要がありそうなのですが、この信号線のArmadilloのGPIO番号/IO番号が知りたいです。何を見れば良いでしょうか?
gpio3の6番です。ですので、armadillo_iotg_g4-con10-ox01f10.dtsのpwdn-gpiosに記載されているものと同じピンになります。
またご指摘のとおり、regにはI2Cアドレスを記述するのですが、1bit目を除いた7bitで記述する必要があります。
ですので、0x20を1bit右にシフトした、0x10を記述してください。
dtsファイルについてはLinuxカーネルのソースコードにまだ加えておりませんが、
弊社で既に作成したものがございます。添付いたしますので、こちらをご参考にしてください。
また、KBCR-S51MMを動作させるためにはdtsファイルとは別にドライバ
(KBCR-S51MMの製品CD-ROM内にあるsample driver/src/linux/drivers/media/i2c/og01h1b.c)が必要になります。
このog01h1b.cをLinuxカーネルのソースコードにコピーした上でビルドを行う必要がありますが、
そのままではビルド時にエラーが発生しますので、
まずはLinuxカーネルのソースコード内の /linux-5.10-5.10.230-r0/drivers/media/i2c/
にog01h1b.cをコピーした上で、添付しているパッチファイルを以下のコマンドで適用してください。
このパッチファイルはog01h1b.cだけでなく、添付しているarmadillo_iotg_g4-con10-og01h1b.dts自体やMakefileなどの差分も含まれています。差分の詳細はパッチファイルの内容をご確認ください。
パッチファイルを適用した後の手順については、
https://manual.atmark-techno.com/armadillo-x2/armadillo-x2_product_manu…
のとおりLinuxカーネルのビルドを行い、
swupdateなどでLinuxカーネルの更新をArmadilloに適用してください。
また、ビルド終了後にarch/arm64/boot/dts/freescale/armadillo_iotg_g4-con10-og01h1b.dtbo
が生成されているはずですので、
https://manual.atmark-techno.com/armadillo-x2/armadillo-x2_product_manu…
の手順を参考にして、Armadilloへのdtboの適用を行ってください。
■カメラの動作方法例
at-debian-imageのコンテナを利用する場合は、
・.confファイルに
add_devices /dev/video2
を追加・必要なパッケージ↓をインストール
weston
gstreamer1.0-imx
libgstreamer-imx
gstreamer1.0-plugins-bad
libgstreamer-plugins-bad1.0-0
gstreamer1.0-plugins-base
libgstreamer-plugins-base1.0-0
gstreamer1.0-plugins-good
libgstreamer1.0-0
gstreamer1.0-tools
gstreamer1.0-imx-tools
v4l-utils
・ArmadilloのHDMI端子とディスプレイを接続
した上で、
を実行すると、ディスプレイにカメラの映像が表示されるはずです。
■カメラの接続方法について
カメラのケーブルを接続する際は、向きに注意してください。
変換基板側コネクタの一番左側の端子(GND)が、X2のCON10の1番に対応します。
誤ってねじれた状態(変換基板側コネクタの一番左側の端子(GND)が、X2のCON10の15番に対応するような接続)で接続して
電源を投入してしまうと、カメラやArmadilloが破損する恐れがあります。
また、CSI1_GPIO0_3V3はArmadilloがカメラを使用するタイミング(gst-launch-1.0コマンド実行時など)にしかHighになりませんので、
ご注意ください。
カーネルのビルド方法などでご不明な点がございましたら、ご遠慮なくおっしゃってください。
よろしくお願いします。