Vision Five 2のM.2 M-keyスロットは現状NVMe SSDが使える


StarFive Vision Five2のM.2 M-keyスロットにまずはM.2 NVMe SSDを入れてみた

root@starfive:~# fdisk -l /dev/nvme0n1
Disk /dev/nvme0n1: 465.76 GiB, 500107862016 bytes, 976773168 sectors
Disk model: Samsung SSD 970 EVO 500GB
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: gpt
Disk identifier: 99EF5891-2C9A-4C91-8A1C-6C1E833E08C4

Device             Start       End   Sectors   Size Type
/dev/nvme0n1p1        34     32767     32734    16M Microsoft reserved
/dev/nvme0n1p2     32768 614432767 614400000   293G Microsoft basic data
/dev/nvme0n1p3 614432768 976771071 362338304 172.8G unknown
root@starfive:~#

まあ、普通に使える。

次に、M.2 SATA SSDを入れてみたが認識はしなかった。

また、Orange Pi 5みたいに ssd-sata モジュールを読み込ませることで認識しないかな?と探してみましたが、Image-69の中には「ssd-sata」という名前がつくファイルは存在しませんでした。

ということで、2022/12/30時点では、Vision Five 2のM.2 M-KeyスロットはM.2 NVMe SSDが利用できるようです。

StarFive Vision Five 2の2022年12月出荷分を使うには面倒くさい手順が必要


StarFiveのRISC-Vコア搭載SoCのJH7110のVision Five 2をKickstarter クラファンのSuper Early Bird – 4GB version が届いた。

しかし、こいつ、いろいろ面倒くさい状態でした。

2022年12月出荷の Vision Five 2は、起動に使われるSPLとU-Bootを更新しないと、Quick Start Guideで案内されているDebianの2022/12/26付けのImage-69版の起動に失敗しました。

更新するには若干面倒な手順が必要でした。

資料について

Vision Five 2に関する資料 は https://doc-en.rvspace.org/Doc_Center/visionfive_2.html を起点に探せる

Quick Start Guide 内にDebianイメージのダウンロードURLが書かれています。

また、githubにStarFiveTech VisionFive2 SDK があり、上記のDebianをソースからビルドする際に必要なモノが揃っています。

用意するもの

・TTLシリアル

シリアルコンソール接続じゃないとSPL/U-Bootの更新作業が行えませんでした。

StarFiveTech VisionFive2 SDKsdcard.img

Debianイメージだと更新に必要な/proc/mtdと/dev/mtd* が作られていませんでした。
SDKサイトにあるsdcard.img は Buildrootと呼ばれる最小構成のLinuxイメージですが、更新に必要なものが揃っていました。

なお、今回使用したのはv2.5.0のsdcard.imgです。

・VisionFive2用のDebianイメージ

最終的にはこのDebianで起動して使う感じです。

更新しないと何が起こるか

SPLとU-Bootを更新しないと何が起こるのか?というと、Debianイメージ2022/12/20付けのImage-55じゃないと起動できませんでした。

更新しない状態で2022/12/26付けImage-69を起動しようとすると、U-Bootの段階でファイルの選択に失敗して起動ができませんでした。

1)TTLシリアルで接続する

SPL/U-Bootを更新するにはUSB-TTLシリアルアダプタを使ってシリアル接続して操作しないとなりません。

繋ぐ場所はQuick Start Guideの Using a USB to Serial Converter for Windowsに書いてある様にGPIO端子です。

2)Buildrootで起動

まずはStarFiveTech VisionFive2 SDKのsdcard.imgをmicroSDに書き込んで起動します。

起動後、ログインして、/dev/mtd*と/proc/mtdがあることを確認します。

# ls -l /dev/mtd*
crw-------    1 root     root       90,   0 Jan  1 00:00 /dev/mtd0
crw-------    1 root     root       90,   1 Jan  1 00:00 /dev/mtd0ro
crw-------    1 root     root       90,   2 Jan  1 00:00 /dev/mtd1
crw-------    1 root     root       90,   3 Jan  1 00:00 /dev/mtd1ro
crw-------    1 root     root       90,   4 Jan  1 00:00 /dev/mtd2
crw-------    1 root     root      `90,   5 Jan  1 00:00 /dev/mtd2ro
brw-rw----    1 root     disk       31,   0 Jan  1 00:00 /dev/mtdblock0
brw-rw----    1 root     disk       31,   1 Jan  1 00:00 /dev/mtdblock1
brw-rw----    1 root     disk       31,   2 Jan  1 00:00 /dev/mtdblock2
# ls -l /proc/mtd*
-r--r--r--    1 root     root          `  0 Jan  1 00:09 /proc/mtd
#

3)更新用ファイルの転送

StarFiveTech VisionFive2 SDKの「u-boot-spl.bin.normal.out」と「visionfive2_fw_payload.img」を別のPCでダウンロードしてからscpコマンドなどでBuildrootのLinux内に転送します。

BuildrootのLinuxはsshdが動いており、rootユーザのログインも許可されているので、TeraTermなどから接続して、scpでコピーすると良いでしょう。

4)SPLとU-bootを更新する

更新手順はQUick Start Guideの「Updating SPL and U-Boot」にあるよう書き込みます。
 ・boot-spl.bin.normal.outを /dev/mtd0
 ・visionfive2_fw_payload.img を /dev/mtd1

書き込みはflashcpコマンドを使います

# cat /proc/mtd
dev:    size   erasesize  name
mtd0: 00020000 00001000 "spl"
mtd1: 00300000 00001000 "uboot"
mtd2: 00100000 00001000 "data"
# flashcp -v u-boot-spl.bin.normal.out /dev/mtd0
Erasing blocks: 32/32 (100%)
Writing data: 124k/124k (100%)
Verifying data: 124k/124k (100%)
# flashcp -v visionfive2_fw_payload.img /dev/mtd1
Erasing blocks: 682/682 (100%)
Writing data: 2727k/2727k (100%)
Verifying data: 2727k/2727k (100%)
#

5) 再起動して反映

再起動するとSPLとU-Bootが更新された状態で起動します。

起動が確認できたら、停止します。

6) Debianイメージで起動

Debianイメージを書き込んだmicroSDに差し替えて電源を入れると、Image-69版のDebianイメージが起動します。

ただ、電源をいれてからX画面が出るまではHDMIには何も出力されないことに注意が必要です。(シリアルコンソールに出力されています)

StarFive Vision Five 2のSPLとU-Bootを更新してImage-69を起動できるようにする


開発陣がImage-69で使っている、ということは、ハードウェア的な何かを更新すればいけるのでは?と感じたので、更新出来る要素を探してみた。

すると、Quick Start Guideに「Updating SPL and U-Boot」という項目を発見。

SPLとU-Bootを更新するといいのかな?と、Image-55で起動して状態を確認してみる

root@starfive:~# cat /proc/mtd
cat: /proc/mtd: No such file or directory
root@starfive:~#

Image-55では/dev/mtdはないようだ

mtd-utilsをインストール

root@starfive:~# apt install mtd-utils
Reading package lists... Done
Building dependency tree... Done
Reading state information... Done
The following additional packages will be installed:
  libiniparser1 liblzo2-2
The following NEW packages will be installed:
  libiniparser1 liblzo2-2 mtd-utils
0 upgraded, 3 newly installed, 0 to remove and 0 not upgraded.
Need to get 303 kB of archives.
After this operation, 1275 kB of additional disk space will be used.
Do you want to continue? [Y/n] y
<略>
root@starfive:~# 

ただ、再起動しても /dev/mtd はできなかった

root@starfive:~# ls -l /dev/*mtd*
ls: cannot access '/dev/*mtd*': No such file or directory
root@starfive:~#

では、Buildrootの方はどうなのか?と、SDK v2.5.0のsdcard.imgで起動して確認

# ls -l /dev/mtd*
crw-------    1 root     root       90,   0 Jan  1 00:00 /dev/mtd0
crw-------    1 root     root       90,   1 Jan  1 00:00 /dev/mtd0ro
crw-------    1 root     root       90,   2 Jan  1 00:00 /dev/mtd1
crw-------    1 root     root       90,   3 Jan  1 00:00 /dev/mtd1ro
crw-------    1 root     root       90,   4 Jan  1 00:00 /dev/mtd2
crw-------    1 root     root      `90,   5 Jan  1 00:00 /dev/mtd2ro
brw-rw----    1 root     disk       31,   0 Jan  1 00:00 /dev/mtdblock0
brw-rw----    1 root     disk       31,   1 Jan  1 00:00 /dev/mtdblock1
brw-rw----    1 root     disk       31,   2 Jan  1 00:00 /dev/mtdblock2
# ls -l /proc/mtd*
-r--r--r--    1 root     root          `  0 Jan  1 00:09 /proc/mtd
#

こちらでは/dev/mtdのデバイスファイルと/proc/mtdがありました。

「cat /proc/mtd」でmtdの中身を確認します。

# cat /proc/mtd
dev:    size   erasesize  name
mtd0: 00020000 00001000 "spl"
mtd1: 00300000 00001000 "uboot"
mtd2: 00100000 00001000 "data"
#

書き込みに使うflashcpコマンドがあるかを確認します

# flashcp

Flash Copy - Written by Abraham van der Merwe <abraham@2d3d.co.za>

usage: flashcp [ -v | --verbose | -A | --erase-all ] <filename> <device>
       flashcp -h | --help
       flashcp -V | --version

   -h | --help      Show this help message
   -v | --verbose   Show progress reports
   -p | --partition Only copy different block from file to device
   -A | --erase-all Erases the whole device regardless of the image size
   -V | --version   Show version information and exit
   <filename>       File which you want to copy to flash
   <device>         Flash device to write to (e.g. /dev/mtd0, /dev/mtd1, etc.)

#

つぎに、アップデートに使うファイルを確認します。

Updating SPL and U-Boot を見ると「u-boot-spl.bin.normal.out」と「visionfive2_fw_payload.img」をflashcpコマンドで書き込んでいるのでVisionFive2 Software v2.5.0にあるファイルをダウンロードかけてみると・・・

# wget https://github.com/starfive-tech/VisionFive2/releases/download/VF2_v2.5.0
/visionfive2_fw_payload.img
wget: not an http or ftp url: https://github.com/starfive-tech/VisionFive2/releases/download/VF2_v2.5.0/visionfive2_fw_payload.img
# curl -O https://github.com/starfive-tech/VisionFive2/releases/download/VF2_v2.
5.0/visionfive2_fw_payload.img
-sh: curl: not found
#

Buildroot環境にあるコマンドだとダウンロードがうまくいかない。wgetコマンドはBusyBox v1.34.1 のものだったが、https非対応であるようだ。

sshdは動いているようなので、sshでWindowsから接続して、scpでファイルを送り込みました。

# ls -l
total 2916
drwxr-xr-x    2 root     root          1024 Dec 25  2022 ISP
drwxr-xr-x    2 root     root          1024 Dec 25  2022 e24
drwxr-xr-x    2 root     root          1024 Dec 25  2022 mailbox
-rwxrwxrwx    1 root     root         22984 Dec 25  2022 mjpeg_dec_test
-rwxr-xr-x    1 root     root           123 Dec 25  2022 run_weston.sh
-rw-------    1 root     root        127816 Dec 30  2022 u-boot-spl.bin.normal.out
-rwxr-xr-x    1 root     root          2894 Dec 25  2022 usb_device.sh
-rwxrwxrwx    1 root     root         18768 Dec 25  2022 video_dec_test
-rwxrwxrwx    1 root     root         18808 Dec 25  2022 video_enc_test
-rw-------    1 root     root       2793045 Dec 30  2022 visionfive2_fw_payload.img
#

転送できたので、flashcpコマンドで書き込みます。

# cat /proc/mtd
dev:    size   erasesize  name
mtd0: 00020000 00001000 "spl"
mtd1: 00300000 00001000 "uboot"
mtd2: 00100000 00001000 "data"
# flashcp -v u-boot-spl.bin.normal.out /dev/mtd0
Erasing blocks: 32/32 (100%)
Writing data: 124k/124k (100%)
Verifying data: 124k/124k (100%)
# flashcp -v visionfive2_fw_payload.img /dev/mtd1
Erasing blocks: 682/682 (100%)
Writing data: 2727k/2727k (100%)
Verifying data: 2727k/2727k (100%)
#

アップデート後のdmesgを取ってみました

# dmesg
[    0.000000] Linux version 5.15.0 (jenkins@soft05) (riscv64-buildroot-linux-gnu-gcc.br_real (Buildroot VF2_v2.5.0) 10.3.0, GNU ld (GNU Binutils) 2.36.1) #1 SMP Sun Dec 25 20:59:22 CST 2022
[    0.000000] OF: fdt: Ignoring memory range 0x40000000 - 0x40200000
[    0.000000] Machine model: StarFive VisionFive V2
[    0.000000] earlycon: sbi0 at I/O port 0x0 (options '')
[    0.000000] printk: bootconsole [sbi0] enabled
[    0.000000] efi: UEFI not found.
[    0.000000] Reserved memory: created CMA memory pool at 0x0000000080000000, size 512 MiB
[    0.000000] OF: reserved mem: initialized node linux,cma, compatible id shared-dma-pool
[    0.000000] Zone ranges:
[    0.000000]   DMA32    [mem 0x0000000040200000-0x00000000ffffffff]
[    0.000000]   Normal   [mem 0x0000000100000000-0x000000013fffffff]
[    0.000000] Movable zone start for each node
[    0.000000] Early memory node ranges
[    0.000000]   node   0: [mem 0x0000000040200000-0x00000000c010ffff]
[    0.000000]   node   0: [mem 0x00000000c0110000-0x00000000c01fffff]
[    0.000000]   node   0: [mem 0x00000000c0200000-0x000000013fffffff]
[    0.000000] Initmem setup node 0 [mem 0x0000000040200000-0x000000013fffffff]
[    0.000000] SBI specification v0.3 detected
[    0.000000] SBI implementation ID=0x1 Version=0x10000
[    0.000000] SBI TIME extension detected
[    0.000000] SBI IPI extension detected
[    0.000000] SBI RFENCE extension detected
[    0.000000] SBI v0.2 HSM extension detected
[    0.000000] CPU with hartid=0 is not available
[    0.000000] CPU with hartid=0 is not available
[    0.000000] riscv: ISA extensions acdfim
[    0.000000] riscv: ELF capabilities acdfim
[    0.000000] percpu: Embedded 17 pages/cpu s31528 r8192 d29912 u69632
[    0.000000] pcpu-alloc: s31528 r8192 d29912 u69632 alloc=17*4096
[    0.000000] pcpu-alloc: [0] 0 [0] 1 [0] 2 [0] 3
[    0.000000] Built 1 zonelists, mobility grouping on.  Total pages: 1033735
[    0.000000] Kernel command line: earlyprintk console=ttyS0,115200 debug rootwait earlycon=sbi root=/dev/mmcblk1p4
[    0.000000] Unknown command line parameters: earlyprintk
[    0.000000] Dentry cache hash table entries: 524288 (order: 10, 4194304 bytes, linear)
[    0.000000] Inode-cache hash table entries: 262144 (order: 9, 2097152 bytes, linear)
[    0.000000] mem auto-init: stack:off, heap alloc:off, heap free:off
[    0.000000] software IO TLB: mapped [mem 0x00000000fbfff000-0x00000000fffff000] (64MB)
[    0.000000] Memory: 3338036K/4192256K available (9878K kernel code, 4982K rwdata, 4096K rodata, 2191K init, 401K bss, 329932K reserved, 524288K cma-reserved)
[    0.000000] SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=4, Nodes=1
[    0.000000] rcu: Hierarchical RCU implementation.
[    0.000000] rcu:     RCU restricting CPUs from NR_CPUS=8 to nr_cpu_ids=4.
[    0.000000] rcu:     RCU debug extended QS entry/exit.
[    0.000000]  Tracing variant of Tasks RCU enabled.
[    0.000000] rcu: RCU calculated value of scheduler-enlistment delay is 10 jiffies.
[    0.000000] rcu: Adjusting geometry for rcu_fanout_leaf=16, nr_cpu_ids=4
[    0.000000] NR_IRQS: 64, nr_irqs: 64, preallocated irqs: 0
[    0.000000] CPU with hartid=0 is not available
[    0.000000] riscv-intc: unable to find hart id for /cpus/cpu@0/interrupt-controller
[    0.000000] riscv-intc: 64 local interrupts mapped
[    0.000000] plic: plic@c000000: mapped 136 interrupts with 4 handlers for 9 contexts.
[    0.000000] random: get_random_bytes called from start_kernel+0x4d0/0x6e2 with crng_init=0
[    0.000000] riscv_timer_init_dt: Registering clocksource cpuid [0] hartid [1]
[    0.000000] clocksource: riscv_clocksource: mask: 0xffffffffffffffff max_cycles: 0x1d854df40, max_idle_ns: 881590404240 ns
[    0.000001] sched_clock: 64 bits at 4MHz, resolution 250ns, wraps every 2199023255500ns
[    0.008243] clocksource: timer@13050000.ch0: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.018466] clocksource: timer@13050000.ch1: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.028787] clocksource: timer@13050000.ch2: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.039094] clocksource: timer@13050000.ch3: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.049571] Console: colour dummy device 80x25
[    0.053981] Calibrating delay loop (skipped), value calculated using timer frequency.. 8.00 BogoMIPS (lpj=40000)
[    0.064174] pid_max: default: 32768 minimum: 301
[    0.069014] Mount-cache hash table entries: 8192 (order: 4, 65536 bytes, linear)
[    0.076409] Mountpoint-cache hash table entries: 8192 (order: 4, 65536 bytes, linear)
[    0.085655] ASID allocator disabled
[    0.089175] rcu: Hierarchical SRCU implementation.
[    0.094094] EFI services will not be available.
[    0.098933] smp: Bringing up secondary CPUs ...
[    0.105034] smp: Brought up 1 node, 4 CPUs
[    0.110198] devtmpfs: initialized
[    0.120823] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604462750000 ns
[    0.130607] futex hash table entries: 1024 (order: 4, 65536 bytes, linear)
[    0.151166] pinctrl core: initialized pinctrl subsystem
[    0.157205] NET: Registered PF_NETLINK/PF_ROUTE protocol family
[    0.163734] cpuidle: using governor menu
[    0.189221] platform soc:dsi-output: Fixing up cyclic dependency with 29400000.dc8200
[    0.197521] platform 295d0000.mipi: Fixing up cyclic dependency with soc:dsi-output
[    0.205502] platform 29590000.hdmi: Fixing up cyclic dependency with 29400000.dc8200
[    0.225091] HugeTLB registered 1.00 GiB page size, pre-allocated 0 pages
[    0.231717] HugeTLB registered 2.00 MiB page size, pre-allocated 0 pages
[    0.241655] vgaarb: loaded
[    0.244522] SCSI subsystem initialized
[    0.248336] libata version 3.00 loaded.
[    0.252291] usbcore: registered new interface driver usbfs
[    0.257734] usbcore: registered new interface driver hub
[    0.263186] usbcore: registered new device driver usb
[    0.268474] mc: Linux media interface: v0.10
[    0.272682] videodev: Linux video capture interface: v2.00
[    0.278405] Advanced Linux Sound Architecture Driver Initialized.
[    0.284794] Bluetooth: Core ver 2.22
[    0.288327] NET: Registered PF_BLUETOOTH protocol family
[    0.293660] Bluetooth: HCI device and connection manager initialized
[    0.300090] Bluetooth: HCI socket layer initialized
[    0.305017] Bluetooth: L2CAP socket layer initialized
[    0.310149] Bluetooth: SCO socket layer initialized
[    0.315356] clocksource: Switched to clocksource riscv_clocksource
[    0.328581] NET: Registered PF_INET protocol family
[    0.334031] IP idents hash table entries: 65536 (order: 7, 524288 bytes, linear)
[    0.345382] tcp_listen_portaddr_hash hash table entries: 2048 (order: 4, 81920 bytes, linear)
[    0.353945] TCP established hash table entries: 32768 (order: 6, 262144 bytes, linear)
[    0.362230] TCP bind hash table entries: 32768 (order: 8, 1048576 bytes, linear)
[    0.370743] TCP: Hash tables configured (established 32768 bind 32768)
[    0.377469] UDP hash table entries: 2048 (order: 5, 196608 bytes, linear)
[    0.384379] UDP-Lite hash table entries: 2048 (order: 5, 196608 bytes, linear)
[    0.391965] NET: Registered PF_UNIX/PF_LOCAL protocol family
[    0.398209] RPC: Registered named UNIX socket transport module.
[    0.404055] RPC: Registered udp transport module.
[    0.408845] RPC: Registered tcp transport module.
[    0.413588] RPC: Registered tcp NFSv4.1 backchannel transport module.
[    0.420816] PCI: CLS 0 bytes, default 64
[    0.425299] Initialise system trusted keyrings
[    0.425704] Unpacking initramfs...
[    0.433863] workingset: timestamp_bits=62 max_order=20 bucket_order=0
[    0.446313] NFS: Registering the id_resolver key type
[    0.451332] Key type id_resolver registered
[    0.455558] Key type id_legacy registered
[    0.459703] nfs4filelayout_init: NFSv4 File Layout Driver Registering...
[    0.466391] nfs4flexfilelayout_init: NFSv4 Flexfile Layout Driver Registering...
[    0.473864] ntfs: driver 2.1.32 [Flags: R/W].
[    0.478533] jffs2: version 2.2. (NAND) \xc2\xa9 2001-2006 Red Hat, Inc.
[    0.484997] fuse: init (API version 7.34)
[    0.528448] NET: Registered PF_ALG protocol family
[    0.533184] Key type asymmetric registered
[    0.537378] Asymmetric key parser 'x509' registered
[    0.542368] Block layer SCSI generic (bsg) driver version 0.4 loaded (major 249)
[    0.549756] io scheduler mq-deadline registered
[    0.554323] io scheduler kyber registered
[    0.558889] start plist test
[    0.565866] end plist test
[    0.663691] clk-starfive-jh7110 13020000.clock-controller: starfive JH7110 clkgen init successfully.
[    0.673946] L2CACHE: DataError @ 0x00000000.08040140
[    0.678932] L2CACHE: DataFail @ 0x00000000.08040074
[    0.683854] L2CACHE: No. of Banks in the cache: 8
[    0.688569] L2CACHE: No. of ways per bank: 16
[    0.692969] L2CACHE: Sets per bank: 256
[    0.696883] L2CACHE: Bytes per cache block: 64
[    0.701375] L2CACHE: Index of the largest way enabled: 15
[    0.707164] jh7110-pmu 17030000.power-controller: registered 8 power domains
[    0.775324] Serial: 8250/16550 driver, 6 ports, IRQ sharing disabled
[    0.784547] @@#########################@@
[    0.826674] @@ dev ptr:ffffffe0bfee0000/1500/1
[    0.831285] PVR_K:  1: Read BVNC 36.50.54.182 from HW device registers
[    0.837831] PVR_K:  1: RGX Device registered BVNC 36.50.54.182 with 1 core in the system
[    0.847130] [drm] Initialized pvr 1.17.6210866 20170530 for 18000000.gpu on minor 0
[    0.863772] loop: module loaded
[    0.869330] spi-nor spi0.0: gd25lq128d (16384 Kbytes)
[    6.207313] Initramfs unpacking failed: invalid magic at start of compressed archive
[    6.382120] Freeing initrd memory: 122788K
[    6.397795] 3 fixed-partitions partitions found on MTD device 13010000.spi.0
[    6.404786] Creating 3 MTD partitions on "13010000.spi.0":
[    6.410373] 0x000000000000-0x000000020000 : "spl"
[    6.416957] 0x000000100000-0x000000400000 : "uboot"
[    6.423312] 0x000000f00000-0x000001000000 : "data"
[    6.430679] libphy: Fixed MDIO Bus: probed
[    6.436258] CAN device driver interface
[    6.440613] starfive-eth-plat 16030000.ethernet: force_sf_dma_mode is ignored if force_thresh_dma_mode is set.
[    6.450922] starfive-eth-plat 16030000.ethernet: User ID: 0x41, Synopsys ID: 0x52
[    6.458349] starfive-eth-plat 16030000.ethernet:     DWMAC4/5
[    6.463877] starfive-eth-plat 16030000.ethernet: DMA HW capability register supported
[    6.471776] starfive-eth-plat 16030000.ethernet: RX Checksum Offload Engine supported
[    6.479660] starfive-eth-plat 16030000.ethernet: Wake-Up On Lan supported
[    6.486512] starfive-eth-plat 16030000.ethernet: TSO supported
[    6.492389] starfive-eth-plat 16030000.ethernet: Enable RX Mitigation via HW Watchdog Timer
[    6.500811] starfive-eth-plat 16030000.ethernet: Enabled Flow TC (entries=1)
[    6.507917] starfive-eth-plat 16030000.ethernet: TSO feature enabled
[    6.514316] starfive-eth-plat 16030000.ethernet: Using 40 bits DMA width
[    6.763129] libphy: stmmac: probed
[    6.766500] YT8531 Gigabit Ethernet stmmac-0:00: attached PHY driver (mii_bus:phy_addr=stmmac-0:00, irq=POLL)
[    6.776447] YT8531 Gigabit Ethernet stmmac-0:01: attached PHY driver (mii_bus:phy_addr=stmmac-0:01, irq=POLL)
[    6.787641] starfive-eth-plat 16040000.ethernet: force_sf_dma_mode is ignored if force_thresh_dma_mode is set.
[    6.797953] starfive-eth-plat 16040000.ethernet: User ID: 0x41, Synopsys ID: 0x52
[    6.805384] starfive-eth-plat 16040000.ethernet:     DWMAC4/5
[    6.810907] starfive-eth-plat 16040000.ethernet: DMA HW capability register supported
[    6.818806] starfive-eth-plat 16040000.ethernet: RX Checksum Offload Engine supported
[    6.826691] starfive-eth-plat 16040000.ethernet: Wake-Up On Lan supported
[    6.833525] starfive-eth-plat 16040000.ethernet: TSO supported
[    6.839431] starfive-eth-plat 16040000.ethernet: Enable RX Mitigation via HW Watchdog Timer
[    6.847844] starfive-eth-plat 16040000.ethernet: Enabled Flow TC (entries=1)
[    6.854933] starfive-eth-plat 16040000.ethernet: TSO feature enabled
[    6.861359] starfive-eth-plat 16040000.ethernet: Using 40 bits DMA width
[    7.109746] libphy: stmmac: probed
[    7.113084] YT8512B Ethernet stmmac-1:00: attached PHY driver (mii_bus:phy_addr=stmmac-1:00, irq=POLL)
[    7.122471] YT8512B Ethernet stmmac-1:03: attached PHY driver (mii_bus:phy_addr=stmmac-1:03, irq=POLL)
[    7.133324] Intel(R) Wireless WiFi driver for Linux
[    7.140053] cdns3-starfive 10210000.usbdrd: usb mode 2 2.0 probe success
[    7.147467] usbcore: registered new interface driver uas
[    7.152754] usbcore: registered new interface driver usb-storage
[    7.159535] starfive-rtc 17040000.rtc: registered as rtc0
[    7.164871] starfive-rtc 17040000.rtc: setting system clock to 2001-01-01T00:33:55 UTC (978309235)
[    7.174030] i2c_dev: i2c /dev entries driver
[    7.178493] usbcore: registered new interface driver uvcvideo
[    7.185331] starfive-wdt 13070000.wdog: Heartbeat: timeout=15, count/2=180000000 (0aba9500)
[    7.194156] Bluetooth: HCI UART driver ver 2.3
[    7.198551] Bluetooth: HCI UART protocol H4 registered
[    7.203940] starfive-cpufreq soc:starfive,jh7110-cpufreq: Failed to get regulator for cpu!
[    7.212154] starfive-cpufreq soc:starfive,jh7110-cpufreq: Failed to init starfive cpu dvfs info
[    7.221439] sdhci: Secure Digital Host Controller Interface driver
[    7.227571] sdhci: Copyright(c) Pierre Ossman
[    7.232004] Synopsys Designware Multimedia Card Interface Driver
[    7.238377] sdhci-pltfm: SDHCI platform and OF driver helper
[    7.244755] jh7110-sec 16000000.crypto: Unable to request sec_m dma channel in DMA channel
[    7.252976] jh7110-sec 16000000.crypto: Cannot initial dma chan
[    7.259237] usbcore: registered new interface driver usbhid
[    7.264741] usbhid: USB HID core driver
[    7.268901] usbcore: registered new interface driver snd-usb-audio
[    7.278417] NET: Registered PF_PACKET protocol family
[    7.283413] can: controller area network core
[    7.287943] NET: Registered PF_CAN protocol family
[    7.292678] can: raw protocol
[    7.295732] can: broadcast manager protocol
[    7.299963] can: netlink gateway - max_hops=1
[    7.304665] Bluetooth: RFCOMM TTY layer initialized
[    7.309511] Bluetooth: RFCOMM socket layer initialized
[    7.314692] Bluetooth: RFCOMM ver 1.11
[    7.318535] Bluetooth: BNEP (Ethernet Emulation) ver 1.3
[    7.323859] Bluetooth: BNEP filters: protocol multicast
[    7.329172] Bluetooth: BNEP socket layer initialized
[    7.334351] 9pnet: Installing 9P2000 support
[    7.338620] Key type dns_resolver registered
[    7.343642] Loading compiled-in X.509 certificates
[    7.384232] starfive_jh7110-pinctrl 13040000.gpio: SiFive GPIO chip registered 64 GPIOs
[    7.392927] starfive_jh7110-pinctrl 17020000.gpio: SiFive GPIO chip registered 4 GPIOs
[    7.401023] pl08xdmac 16008000.sec_dma: initialized 8 virtual memcpy channels
[    7.408123] pl08xdmac 16008000.sec_dma: initialized 16 virtual slave channels
[    7.416958] debugfs: Directory '16008000.sec_dma' with parent 'dmaengine' already present!
[    7.425182] pl08xdmac 16008000.sec_dma: DMA: PL080 rev0 at 0x16008000 irq 23
[    7.432547] ssp-pl022 10060000.spi: ARM PL022 driver for StarFive SoC platform, device ID: 0x00041022
[    7.441730] ssp-pl022 10060000.spi: mapped registers from 0x0000000010060000 to (____ptrval____)
[    7.451001] ssp-pl022 10060000.spi: Requested frequency: 10000000 Hz is unsupported,select by default 8250000 Hz
[    7.461503] ssp-pl022 10060000.spi: will use autosuspend for runtime pm, delay 100ms
[    7.470525] i2c 2-0045: Fixing up cyclic dependency with 295d0000.mipi
[    7.477283] seeed_panel 2-0045: Unknown Atmel firmware revision: 0x00
[    7.483851] i2c 2-0019: Fixing up cyclic dependency with 295d0000.mipi
[    7.491738] at24 5-0050: supply vcc not found, using dummy regulator
[    7.498857] at24 5-0050: 512 byte 24c04 EEPROM, writable, 16 bytes/write
[    7.507724] axp15060-regulator 5-0036: Register mipi_0p9 done! vol range:900 ~ 900 mV
[    7.516993] axp15060-regulator 5-0036: Register hdmi_1p8 done! vol range:1800 ~ 1800 mV
[    7.526409] axp15060-regulator 5-0036: Register hdmi_0p9 done! vol range:900 ~ 900 mV
[    7.535688] axp15060-regulator 5-0036: Register cpu_vdd done! vol range:500 ~ 1540 mV
[    7.544222] i2c 6-0010: Fixing up cyclic dependency with 19800000.vin_sysctl
[    7.551632] imx219 6-0010: supply VANA not found, using dummy regulator
[    7.558321] imx219 6-0010: supply VDIG not found, using dummy regulator
[    7.564921] imx219 6-0010: supply VDDL not found, using dummy regulator
[    7.579037] imx219 6-0010: failed to read chip id 219
[    7.584227] imx219: probe of 6-0010 failed with error -5
[    7.592001] pcie_plda 2b000000.pcie: host bridge /soc/pcie@2B000000 ranges:
[    7.598976] pcie_plda 2b000000.pcie:      MEM 0x0030000000..0x0037ffffff -> 0x0030000000
[    7.607084] pcie_plda 2b000000.pcie:      MEM 0x0900000000..0x093fffffff -> 0x0900000000
[    7.615243] ATR entry: 0x0940000000 -> 0x0000000000 [0x0010000000] (param: 0x000001)
[    7.623021] ATR entry: 0x0030000000 -> 0x0030000000 [0x0008000000] (param: 0x000000)
[    7.630814] ATR entry: 0x0900000000 -> 0x0900000000 [0x0040000000] (param: 0x000000)
[    7.985453] pcie_plda 2b000000.pcie: Port link up.
[    7.990332] pcie_plda 2b000000.pcie: PCI host bridge to bus 0000:00
[    7.996551] pci_bus 0000:00: root bus resource [bus 00-ff]
[    8.002074] pci_bus 0000:00: root bus resource [mem 0x30000000-0x37ffffff]
[    8.009025] pci_bus 0000:00: root bus resource [mem 0x900000000-0x93fffffff pref]
[    8.016589] pci 0000:00:00.0: [1556:1111] type 01 class 0x060400
[    8.022624] pci 0000:00:00.0: reg 0x10: [mem 0x00000000-0xffffffff 64bit pref]
[    8.029962] pci 0000:00:00.0: supports D1 D2
[    8.034226] pci 0000:00:00.0: PME# supported from D0 D1 D2 D3hot D3cold
[    8.044390] pci 0000:00:00.0: bridge configuration invalid ([bus 00-00]), reconfiguring
[    8.052477] pci 0000:01:00.0: [1106:3483] type 00 class 0x0c0330
[    8.058442] pci 0000:01:00.0: reg 0x10: [mem 0x00000000-0x00000fff 64bit]
[    8.065338] pci 0000:01:00.0: PME# supported from D0 D3cold
[    8.074192] pci_bus 0000:01: busn_res: [bus 01-ff] end is updated to 01
[    8.080787] pci 0000:00:00.0: BAR 0: no space for [mem size 0x100000000 64bit pref]
[    8.088467] pci 0000:00:00.0: BAR 0: failed to assign [mem size 0x100000000 64bit pref]
[    8.096538] pci 0000:00:00.0: BAR 8: assigned [mem 0x30000000-0x300fffff]
[    8.103363] pci 0000:01:00.0: BAR 0: assigned [mem 0x30000000-0x30000fff 64bit]
[    8.110755] pci 0000:00:00.0: PCI bridge to [bus 01]
[    8.115772] pci 0000:00:00.0:   bridge window [mem 0x30000000-0x300fffff]
[    8.122703] pci 0000:00:00.0: enabling device (0000 -> 0002)
[    8.128347] pci 0000:01:00.0: enabling device (0000 -> 0002)
[    8.134091] pci 0000:01:00.0: quirk_usb_early_handoff+0x0/0x9d4 took 11130 usecs
[    8.141710] xhci_hcd 0000:01:00.0: xHCI Host Controller
[    8.146942] xhci_hcd 0000:01:00.0: new USB bus registered, assigned bus number 1
[    8.154729] xhci_hcd 0000:01:00.0: hcc params 0x002841eb hci version 0x100 quirks 0x0000040000000890
[    8.163879] pcie_plda 2b000000.pcie: msi#0 address_hi 0x0 address_lo 0x190
[    8.171111] xhci_hcd 0000:01:00.0: xHCI Host Controller
[    8.176291] xhci_hcd 0000:01:00.0: new USB bus registered, assigned bus number 2
[    8.183725] xhci_hcd 0000:01:00.0: Host supports USB 3.0 SuperSpeed
[    8.190808] hub 1-0:1.0: USB hub found
[    8.194517] hub 1-0:1.0: 1 port detected
[    8.199526] hub 2-0:1.0: USB hub found
[    8.203235] hub 2-0:1.0: 4 ports detected
[    8.210087] pcie_plda 2c000000.pcie: host bridge /soc/pcie@2C000000 ranges:
[    8.217044] pcie_plda 2c000000.pcie:      MEM 0x0038000000..0x003fffffff -> 0x0038000000
[    8.225152] pcie_plda 2c000000.pcie:      MEM 0x0980000000..0x09bfffffff -> 0x0980000000
[    8.233353] ATR entry: 0x09c0000000 -> 0x0000000000 [0x0010000000] (param: 0x000001)
[    8.241109] ATR entry: 0x0038000000 -> 0x0038000000 [0x0008000000] (param: 0x000000)
[    8.248900] ATR entry: 0x0980000000 -> 0x0980000000 [0x0040000000] (param: 0x000000)
[    8.515415] usb 1-1: new high-speed USB device number 2 using xhci_hcd
[    8.685439] pcie_plda 2c000000.pcie: Port link down, exit.
[    8.704503] clk-starfive-jh7110-vout 295c0000.clock-controller: starfive JH7110 clk_vout init successfully.
[    8.725891] clk-starfive-jh7110-isp 19810000.clock-controller: starfive JH7110 clk_isp init successfully.
[    8.736051] dw_axi_dmac_platform 16050000.dma-controller: DesignWare AXI DMA Controller, 4 channels
[    8.746127] printk: console [ttyS0] disabled
[    8.770588] 10000000.serial: ttyS0 at MMIO 0x10000000 (irq = 17, base_baud = 1500000) is a 16550A
[    8.771779] hub 1-1:1.0: USB hub found
[    8.786961] printk: console [ttyS0] enabled
[    8.787109] hub 1-1:1.0: 4 ports detected
[    8.841961] printk: bootconsole [sbi0] disabled
[    8.954754] jh7110-vin 19800000.vin_sysctl: stfcamss probe enter!
[    8.997053] jh7110-vin 19800000.vin_sysctl: stfcamss probe success!
[    9.040422] dwmmc_starfive 16010000.sdio0: IDMAC supports 32-bit address mode.
[    9.040799] dwmmc_starfive 16020000.sdio1: IDMAC supports 32-bit address mode.
[    9.041006] jh7110-sec 16000000.crypto: will run requests pump with realtime priority
[    9.044208] jh7110-sec 16000000.crypto: Initialized
[    9.045266] starfive-i2s 120b0000.i2stx_4ch0:  designware: play supported
[    9.045276] starfive-i2s 120b0000.i2stx_4ch0: designware: i2s master mode supported
[    9.045498] sf-mipi-dphy-tx 295e0000.mipi-dphy: sf_dphy_probe begin
[    9.045508] sf-mipi-dphy-tx 295e0000.mipi-dphy: ===> sf_dphy_probe enter, 445
[    9.045638] sf-mipi-dphy-tx 295e0000.mipi-dphy: control ECO
[    9.045659] sf-mipi-dphy-tx 295e0000.mipi-dphy: supply mipi_1p8 not found, using dummy regulator
[    9.045971] sf-mipi-dphy-tx 295e0000.mipi-dphy: sf_dphy_probe end
[    9.046172] cdns-dsi 295d0000.mipi: dsi_sys_clk = 297000000
[    9.046408] cdns-dsi 295d0000.mipi: starfive dsi bind end
[    9.048579] of_cfs_init
[    9.048611] of_cfs_init: OK
[    9.049136] starfive-pwmdac 100b0000.pwmdac: clk_apb0 = 49500000, clk_pwmdac_apb = 49500000, clk_pwmdac_core = 4068493
[    9.049643] cfg80211: Loading compiled-in X.509 certificates for regulatory database
[    9.087625] dwmmc_starfive 16010000.sdio0: Using internal DMA controller.
[    9.134781] dwmmc_starfive 16020000.sdio1: Using internal DMA controller.
[    9.185846] dwmmc_starfive 16010000.sdio0: Version ID is 290a
[    9.205734] cfg80211: Loaded X.509 cert 'sforshee: 00b28ddf47aef9cea7'
[    9.209707] starfive soc:display-subsystem: bound 29400000.dc8200 (ops 0xffffffff80e75b38)
[    9.209725] innohdmi-starfive 29590000.hdmi: inno hdmi bind begin
[    9.210644] platform regulatory.0: Direct firmware load for regulatory.db failed with error -2
[    9.210658] cfg80211: failed to load regulatory.db
[    9.217676] dwmmc_starfive 16020000.sdio1: Version ID is 290a
[    9.261990] dwmmc_starfive 16010000.sdio0: DW MMC controller at irq 29,32 bit host data width,32 deep fifo
[    9.311953] dwmmc_starfive 16020000.sdio1: DW MMC controller at irq 30,32 bit host data width,32 deep fifo
[    9.352910] mmc_host mmc0: card is non-removable.
[    9.400050] mmc_host mmc1: card is polling.
[    9.438694] innohdmi-starfive 29590000.hdmi: [drm:inno_hdmi_bind] registered Inno HDMI I2C bus driver success
[    9.655377] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 400000Hz, actual 399193HZ div = 248)
[    9.705367] mmc_host mmc1: Bus speed (slot 0) = 198000000Hz (slot req 400000Hz, actual 399193HZ div = 248)
[    9.710002] innohdmi-starfive 29590000.hdmi: HDMI&AUDIO register done.
[    9.915366] usb 1-1.1: new low-speed USB device number 3 using xhci_hcd
[    9.928225] innohdmi-starfive 29590000.hdmi: inno hdmi bind end
[    9.965348] dwmmc_starfive 16020000.sdio1: Unexpected interrupt latency
[   10.015350] dwmmc_starfive 16010000.[   39.615932] mipi_0p9: disabling
sdio0: Unexpected interrupt latency
[   10.015350] dwmmc_starfive 16020000.sdio1: Unexpected interrupt latency
[   10.774854] starfive soc:display-subsystem: bound 29590000.hdmi (ops 0xffffffff80e768e8)
[   10.805348] dwmmc_starfive 16020000.sdio1: Unexpected interrupt latency
[   10.805350] dwmmc_starfive 16010000.sdio0: Unexpected interrupt latency
[   10.913923] vs-simple-encoder soc:dsi-output: encoder_bind begin
[   10.953142] no panel, -517
[   10.970793] vs-simple-encoder soc:dsi-output: encoder_bind error
[   11.005350] dwmmc_starfive 16010000.sdio0: Unexpected interrupt latency
[   11.005351] dwmmc_starfive 16020000.sdio1: Unexpected interrupt latency
[   11.096261] starfive soc:display-subsystem: bound soc:dsi-output (ops 0xffffffff80e76530)
[   11.135348] dwmmc_starfive 16020000.sdio1: Unexpected interrupt latency
[   11.135349] dwmmc_starfive 16010000.sdio0: Unexpected interrupt latency
[   11.236594] [drm] Initialized starfive 1.0.0 20191101 for soc:display-subsystem on minor 1
[   11.275351] dwmmc_starfive 16010000.sdio0: Unexpected interrupt latency
[   11.285347] dwmmc_starfive 16020000.sdio1: Unexpected interrupt latency
[   11.385332] mmc_host mmc1: Bus speed (slot 0) = 198000000Hz (slot req 50000000Hz, actual 49500000HZ div = 2)
[   11.407910] random: fast init done
[   11.472565] mmc1: new high speed SDXC card at address 59b4
[   11.484875] input: TK-FCP026 Series as /devices/platform/soc/2b000000.pcie/pci0000:00/0000:00:00.0/0000:01:00.0/usb1/1-1/1-1.1/1-1.1:1.0/0003:056E:1013.0001/input/input0
[   11.509193] mmcblk1: mmc1:59b4 ED2S5 119 GiB
[   11.607084] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 300000Hz, actual 300000HZ div = 330)
[   11.643201]  mmcblk1: p1 p2 p3 p4
[   11.698744] hid-generic 0003:056E:1013.0001: input: USB HID v1.10 Keyboard [TK-FCP026 Series] on usb-0000:01:00.0-1.1/input0
[   11.800123] input: TK-FCP026 Series System Control as /devices/platform/soc/2b000000.pcie/pci0000:00/0000:00:00.0/0000:01:00.0/usb1/1-1/1-1.1/1-1.1:1.1/0003:056E:1013.0002/input/input1
[   11.975528] input: TK-FCP026 Series Consumer Control as /devices/platform/soc/2b000000.pcie/pci0000:00/0000:00:00.0/0000:01:00.0/usb1/1-1/1-1.1/1-1.1:1.1/0003:056E:1013.0002/input/input2
[   12.083963] hid-generic 0003:056E:1013.0002: input: USB HID v1.10 Device [TK-FCP026 Series] on usb-0000:01:00.0-1.1/input1
[   12.156179] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 200000Hz, actual 200000HZ div = 495)
[   12.665475] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 100000Hz, actual 100000HZ div = 990)
[   13.455437] ALSA device list:
[   13.474832]   #0: Starfive-PWMDAC-Sound-Card
[   13.502734]   #1: Starfive-HDMI-Sound-Card
[   13.535069] Freeing unused kernel image (initmem) memory: 2188K
[   13.541318] Run /init as init process
[   13.545009]   with arguments:
[   13.548031]     /init
[   13.550321]     earlyprintk
[   13.553134]   with environment:
[   13.556329]     HOME=/
[   13.558710]     TERM=linux
[   13.680223] EXT4-fs (mmcblk1p4): mounted filesystem with ordered data mode. Opts: (null). Quota mode: disabled.
[   14.245147] EXT4-fs (mmcblk1p4): re-mounted. Opts: (null). Quota mode: disabled.
[   14.693107] udevd[219]: starting version 3.2.10
[   14.709634] random: udevd: uninitialized urandom read (16 bytes read)
[   14.717375] random: udevd: uninitialized urandom read (16 bytes read)
[   14.723891] random: udevd: uninitialized urandom read (16 bytes read)
[   14.751454] udevd[220]: starting eudev-3.2.10
[   14.859939] vdec: loading out-of-tree module taints kernel.
[   14.867226] cnm_jpu 13090000.jpu: init device.
[   14.872177] SUCCESS alloc_chrdev_region
[   14.873268] vdec 130a0000.vpu_dec: device init.
[   14.880649] SUCCESS alloc_chrdev_region
[   15.436748] starfive-eth-plat 16030000.ethernet eth0: PHY [stmmac-0:00] driver [YT8531 Gigabit Ethernet] (irq=POLL)
[   15.448463] starfive-eth-plat 16030000.ethernet eth0: Register MEM_TYPE_PAGE_POOL RxQ-0
[   16.336734] dwmac4: Master AXI performs fixed burst length
[   16.342309] starfive-eth-plat 16030000.ethernet eth0: No Safety Features support found
[   16.350389] starfive-eth-plat 16030000.ethernet eth0: IEEE 1588-2008 Advanced Timestamp supported
[   16.362590] starfive-eth-plat 16030000.ethernet eth0: configuring for phy/rgmii-id link mode
[   16.374365] starfive-eth-plat 16040000.ethernet eth1: PHY [stmmac-1:00] driver [YT8512B Ethernet] (irq=POLL)
[   16.384428] starfive-eth-plat 16040000.ethernet eth1: Register MEM_TYPE_PAGE_POOL RxQ-0
[   16.392709] dwmac4: Master AXI performs fixed burst length
[   16.398214] starfive-eth-plat 16040000.ethernet eth1: No Safety Features support found
[   16.406156] starfive-eth-plat 16040000.ethernet eth1: IEEE 1588-2008 Advanced Timestamp supported
[   16.416683] starfive-eth-plat 16040000.ethernet eth1: configuring for phy/rgmii-id link mode
[   18.497448] starfive-eth-plat 16040000.ethernet eth1: Link is Up - 100Mbps/Full - flow control off
[   39.615932] mipi_0p9: disabling
#

Buildroot環境のdmesg的にはあまり変化はありませんでした。

Image-69で起動

では、Image-69が起動するか確認してみます。

Image-55の時と同様に起動中はシリアルコンソールのみ、Xが起動するとHDMI出力が現れる形でした。

Xにログインするとこんな感じです。

root@starfive:~# uname -a
Linux starfive 5.15.0-starfive #1 SMP Mon Dec 19 07:56:37 EST 2022 riscv64 GNU/Linux
root@starfive:~#
root@starfive:~# dmesg
[    0.000000] Linux version 5.15.0-starfive (sw_buildbot@mdcsw02) (riscv64-unknown-linux-gnu-gcc (GCC) 10.2.0, GNU ld (GNU Binutils) 2.35) #1 SMP Mon Dec 19 07:56:37 EST 2022
[    0.000000] OF: fdt: Ignoring memory range 0x40000000 - 0x40200000
[    0.000000] Machine model: StarFive VisionFive V2
[    0.000000] earlycon: uart0 at MMIO32 0x0000000010000000 (options '115200')
[    0.000000] printk: bootconsole [uart0] enabled
[    0.000000] efi: UEFI not found.
[    0.000000] Reserved memory: created CMA memory pool at 0x0000000080000000, size 512 MiB
[    0.000000] OF: reserved mem: initialized node linux,cma, compatible id shared-dma-pool
[    0.000000] Zone ranges:
[    0.000000]   DMA32    [mem 0x0000000040200000-0x00000000ffffffff]
[    0.000000]   Normal   [mem 0x0000000100000000-0x000000013fffffff]
[    0.000000] Movable zone start for each node
[    0.000000] Early memory node ranges
[    0.000000]   node   0: [mem 0x0000000040200000-0x00000000c010ffff]
[    0.000000]   node   0: [mem 0x00000000c0110000-0x00000000c01fffff]
[    0.000000]   node   0: [mem 0x00000000c0200000-0x000000013fffffff]
[    0.000000] Initmem setup node 0 [mem 0x0000000040200000-0x000000013fffffff]
[    0.000000] SBI specification v0.3 detected
[    0.000000] SBI implementation ID=0x1 Version=0x10000
[    0.000000] SBI TIME extension detected
[    0.000000] SBI IPI extension detected
[    0.000000] SBI RFENCE extension detected
[    0.000000] SBI v0.2 HSM extension detected
[    0.000000] CPU with hartid=0 is not available
[    0.000000] CPU with hartid=0 is not available
[    0.000000] riscv: ISA extensions acdfim
[    0.000000] riscv: ELF capabilities acdfim
[    0.000000] percpu: Embedded 17 pages/cpu s31528 r8192 d29912 u69632
[    0.000000] pcpu-alloc: s31528 r8192 d29912 u69632 alloc=17*4096
[    0.000000] pcpu-alloc: [0] 0 [0] 1 [0] 2 [0] 3
[    0.000000] Built 1 zonelists, mobility grouping on.  Total pages: 1033735
[    0.000000] Kernel command line: root=/dev/mmcblk1p3 rw console=tty0 console=ttyS0,115200 earlycon rootwait stmmaceth=chain_mode:1 selinux=0
[    0.000000] Unknown command line parameters: stmmaceth=chain_mode:1 selinux=0
[    0.000000] Dentry cache hash table entries: 524288 (order: 10, 4194304 bytes, linear)
[    0.000000] Inode-cache hash table entries: 262144 (order: 9, 2097152 bytes, linear)
[    0.000000] mem auto-init: stack:off, heap alloc:off, heap free:off
[    0.000000] software IO TLB: mapped [mem 0x00000000fbfff000-0x00000000fffff000] (64MB)
[    0.000000] Memory: 3451368K/4192256K available (9884K kernel code, 4982K rwdata, 4096K rodata, 2191K init, 401K bss, 216600K reserved, 524288K cma-reserved)
[    0.000000] SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=4, Nodes=1
[    0.000000] rcu: Hierarchical RCU implementation.
[    0.000000] rcu:     RCU restricting CPUs from NR_CPUS=8 to nr_cpu_ids=4.
[    0.000000] rcu:     RCU debug extended QS entry/exit.
[    0.000000]  Tracing variant of Tasks RCU enabled.
[    0.000000] rcu: RCU calculated value of scheduler-enlistment delay is 10 jiffies.
[    0.000000] rcu: Adjusting geometry for rcu_fanout_leaf=16, nr_cpu_ids=4
[    0.000000] NR_IRQS: 64, nr_irqs: 64, preallocated irqs: 0
[    0.000000] CPU with hartid=0 is not available
[    0.000000] riscv-intc: unable to find hart id for /cpus/cpu@0/interrupt-controller
[    0.000000] riscv-intc: 64 local interrupts mapped
[    0.000000] plic: plic@c000000: mapped 136 interrupts with 4 handlers for 9 contexts.
[    0.000000] random: get_random_bytes called from start_kernel+0x4d0/0x6e2 with crng_init=0
[    0.000000] riscv_timer_init_dt: Registering clocksource cpuid [0] hartid [1]
[    0.000000] clocksource: riscv_clocksource: mask: 0xffffffffffffffff max_cycles: 0x1d854df40, max_idle_ns: 881590404240 ns
[    0.000001] sched_clock: 64 bits at 4MHz, resolution 250ns, wraps every 2199023255500ns
[    0.009003] clocksource: timer@13050000.ch0: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.020327] clocksource: timer@13050000.ch1: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.031659] clocksource: timer@13050000.ch2: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.042985] clocksource: timer@13050000.ch3: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.054473] Console: colour dummy device 80x25
[    0.060660] printk: console [tty0] enabled
[    0.065214] Calibrating delay loop (skipped), value calculated using timer frequency.. 8.00 BogoMIPS (lpj=40000)
[    0.076437] pid_max: default: 32768 minimum: 301
[    0.081664] Mount-cache hash table entries: 8192 (order: 4, 65536 bytes, linear)
[    0.089901] Mountpoint-cache hash table entries: 8192 (order: 4, 65536 bytes, linear)
[    0.099981] ASID allocator disabled
[    0.103919] rcu: Hierarchical SRCU implementation.
[    0.109372] EFI services will not be available.
[    0.114755] smp: Bringing up secondary CPUs ...
[    0.121388] smp: Brought up 1 node, 4 CPUs
[    0.127085] devtmpfs: initialized
[    0.138281] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604462750000 ns
[    0.149143] futex hash table entries: 1024 (order: 4, 65536 bytes, linear)
[    0.170414] pinctrl core: initialized pinctrl subsystem
[    0.177070] NET: Registered PF_NETLINK/PF_ROUTE protocol family
[    0.184291] cpuidle: using governor menu
[    0.210593] platform soc:dsi-output: Fixing up cyclic dependency with 29400000.dc8200
[    0.219775] platform 295d0000.mipi: Fixing up cyclic dependency with soc:dsi-output
[    0.228616] platform 29590000.hdmi: Fixing up cyclic dependency with 29400000.dc8200
[    0.249118] HugeTLB registered 1.00 GiB page size, pre-allocated 0 pages
[    0.256502] HugeTLB registered 2.00 MiB page size, pre-allocated 0 pages
[    0.267098] vgaarb: loaded
[    0.270324] SCSI subsystem initialized
[    0.274695] libata version 3.00 loaded.
[    0.274873] usbcore: registered new interface driver usbfs
[    0.280947] usbcore: registered new interface driver hub
[    0.286840] usbcore: registered new device driver usb
[    0.292683] mc: Linux media interface: v0.10
[    0.297433] videodev: Linux video capture interface: v2.00
[    0.303659] Advanced Linux Sound Architecture Driver Initialized.
[    0.310754] Bluetooth: Core ver 2.22
[    0.314717] NET: Registered PF_BLUETOOTH protocol family
[    0.320574] Bluetooth: HCI device and connection manager initialized
[    0.327572] Bluetooth: HCI socket layer initialized
[    0.332954] Bluetooth: L2CAP socket layer initialized
[    0.338526] Bluetooth: SCO socket layer initialized
[    0.344230] clocksource: Switched to clocksource riscv_clocksource
[    0.358649] NET: Registered PF_INET protocol family
[    0.364690] IP idents hash table entries: 65536 (order: 7, 524288 bytes, linear)
[    0.376739] tcp_listen_portaddr_hash hash table entries: 2048 (order: 4, 81920 bytes, linear)
[    0.386266] TCP established hash table entries: 32768 (order: 6, 262144 bytes, linear)
[    0.395413] TCP bind hash table entries: 32768 (order: 8, 1048576 bytes, linear)
[    0.404830] TCP: Hash tables configured (established 32768 bind 32768)
[    0.412290] UDP hash table entries: 2048 (order: 5, 196608 bytes, linear)
[    0.420066] UDP-Lite hash table entries: 2048 (order: 5, 196608 bytes, linear)
[    0.428465] NET: Registered PF_UNIX/PF_LOCAL protocol family
[    0.435400] RPC: Registered named UNIX socket transport module.
[    0.441924] RPC: Registered udp transport module.
[    0.447117] RPC: Registered tcp transport module.
[    0.452291] RPC: Registered tcp NFSv4.1 backchannel transport module.
[    0.460105] PCI: CLS 0 bytes, default 64
[    0.465110] Initialise system trusted keyrings
[    0.470246] workingset: timestamp_bits=62 max_order=20 bucket_order=0
[    0.474489] Unpacking initramfs...
[    0.483186] NFS: Registering the id_resolver key type
[    0.488817] Key type id_resolver registered
[    0.493433] Key type id_legacy registered
[    0.497973] nfs4filelayout_init: NFSv4 File Layout Driver Registering...
[    0.505391] nfs4flexfilelayout_init: NFSv4 Flexfile Layout Driver Registering...
[    0.513607] ntfs: driver 2.1.32 [Flags: R/W].
[    0.518714] jffs2: version 2.2. (NAND) c 2001-2006 Red Hat, Inc.
[    0.525920] fuse: init (API version 7.34)
[    0.570101] NET: Registered PF_ALG protocol family
[    0.575431] Key type asymmetric registered
[    0.579954] Asymmetric key parser 'x509' registered
[    0.585458] Block layer SCSI generic (bsg) driver version 0.4 loaded (major 249)
[    0.593617] io scheduler mq-deadline registered
[    0.598639] io scheduler kyber registered
[    0.607893] start plist test
[    0.612237] end plist test
[    0.708128] clk-starfive-jh7110 13020000.clock-controller: starfive JH7110 clkgen init successfully.
[    0.719385] L2CACHE: DataError @ 0x00000000.08040140
[    0.724958] L2CACHE: DataFail @ 0x00000000.0804005B
[    0.730422] L2CACHE: No. of Banks in the cache: 8
[    0.735634] L2CACHE: No. of ways per bank: 16
[    0.740443] L2CACHE: Sets per bank: 256
[    0.744693] L2CACHE: Bytes per cache block: 64
[    0.749599] L2CACHE: Index of the largest way enabled: 15
[    0.755895] jh7110-pmu 17030000.power-controller: registered 8 power domains
[    0.823058] Serial: 8250/16550 driver, 6 ports, IRQ sharing disabled
[    0.833017] @@#########################@@
[    0.875351] @@ dev ptr:ffffffe0bfee0000/1500/1
[    0.880510] PVR_K:  1: Read BVNC 36.50.54.182 from HW device registers
[    0.887810] PVR_K:  1: RGX Device registered BVNC 36.50.54.182 with 1 core in the system
[    0.898025] [drm] Initialized pvr 1.17.6210866 20170530 for 18000000.gpu on minor 0
[    0.920407] loop: module loaded
[    0.926442] spi-nor spi0.0: gd25lq128d (16384 Kbytes)
[    1.179648] Freeing initrd memory: 9456K
[    1.200532] 3 fixed-partitions partitions found on MTD device 13010000.spi.0
[    1.208365] Creating 3 MTD partitions on "13010000.spi.0":
[    1.214440] 0x000000000000-0x000000020000 : "spl"
[    1.221389] 0x000000100000-0x000000400000 : "uboot"
[    1.228325] 0x000000f00000-0x000001000000 : "data"
[    1.236236] libphy: Fixed MDIO Bus: probed
[    1.242212] CAN device driver interface
[    1.247071] starfive-eth-plat 16030000.ethernet: force_sf_dma_mode is ignored if force_thresh_dma_mode is set.
[    1.258489] starfive-eth-plat 16030000.ethernet: User ID: 0x41, Synopsys ID: 0x52
[    1.266772] starfive-eth-plat 16030000.ethernet:     DWMAC4/5
[    1.272823] starfive-eth-plat 16030000.ethernet: DMA HW capability register supported
[    1.281466] starfive-eth-plat 16030000.ethernet: RX Checksum Offload Engine supported
[    1.290110] starfive-eth-plat 16030000.ethernet: Wake-Up On Lan supported
[    1.297598] starfive-eth-plat 16030000.ethernet: TSO supported
[    1.304029] starfive-eth-plat 16030000.ethernet: Enable RX Mitigation via HW Watchdog Timer
[    1.313255] starfive-eth-plat 16030000.ethernet: Enabled Flow TC (entries=1)
[    1.321032] starfive-eth-plat 16030000.ethernet: TSO feature enabled
[    1.328044] starfive-eth-plat 16030000.ethernet: Using 40 bits DMA width
[    1.587153] libphy: stmmac: probed
[    1.590928] YT8531 Gigabit Ethernet stmmac-0:00: attached PHY driver (mii_bus:phy_addr=stmmac-0:00, irq=POLL)
[    1.601889] YT8531 Gigabit Ethernet stmmac-0:01: attached PHY driver (mii_bus:phy_addr=stmmac-0:01, irq=POLL)
[    1.614036] starfive-eth-plat 16040000.ethernet: force_sf_dma_mode is ignored if force_thresh_dma_mode is set.
[    1.625459] starfive-eth-plat 16040000.ethernet: User ID: 0x41, Synopsys ID: 0x52
[    1.633716] starfive-eth-plat 16040000.ethernet:     DWMAC4/5
[    1.639785] starfive-eth-plat 16040000.ethernet: DMA HW capability register supported
[    1.648429] starfive-eth-plat 16040000.ethernet: RX Checksum Offload Engine supported
[    1.657077] starfive-eth-plat 16040000.ethernet: Wake-Up On Lan supported
[    1.664566] starfive-eth-plat 16040000.ethernet: TSO supported
[    1.670997] starfive-eth-plat 16040000.ethernet: Enable RX Mitigation via HW Watchdog Timer
[    1.680243] starfive-eth-plat 16040000.ethernet: Enabled Flow TC (entries=1)
[    1.688023] starfive-eth-plat 16040000.ethernet: TSO feature enabled
[    1.695036] starfive-eth-plat 16040000.ethernet: Using 40 bits DMA width
[    1.953570] libphy: stmmac: probed
[    1.957379] YT8512B Ethernet stmmac-1:00: attached PHY driver (mii_bus:phy_addr=stmmac-1:00, irq=POLL)
[    1.967672] YT8512B Ethernet stmmac-1:03: attached PHY driver (mii_bus:phy_addr=stmmac-1:03, irq=POLL)
[    1.979497] Intel(R) Wireless WiFi driver for Linux
[    1.986870] cdns3-starfive 10210000.usbdrd: usb mode 2 2.0 probe success
[    1.995071] usbcore: registered new interface driver uas
[    2.000982] usbcore: registered new interface driver usb-storage
[    2.024572] starfive-rtc 17040000.rtc: registered as rtc0
[    2.030540] starfive-rtc 17040000.rtc: setting system clock to 2001-01-01T00:00:00 UTC (978307200)
[    2.040588] i2c_dev: i2c /dev entries driver
[    2.045561] usbcore: registered new interface driver uvcvideo
[    2.053083] starfive-wdt 13070000.wdog: Heartbeat: timeout=15, count/2=180000000 (0aba9500)
[    2.062844] Bluetooth: HCI UART driver ver 2.3
[    2.067773] Bluetooth: HCI UART protocol H4 registered
[    2.073649] starfive-cpufreq soc:starfive,jh7110-cpufreq: Failed to get regulator for cpu!
[    2.082794] starfive-cpufreq soc:starfive,jh7110-cpufreq: Failed to init starfive cpu dvfs info
[    2.092931] sdhci: Secure Digital Host Controller Interface driver
[    2.099773] sdhci: Copyright(c) Pierre Ossman
[    2.104616] Synopsys Designware Multimedia Card Interface Driver
[    2.111541] sdhci-pltfm: SDHCI platform and OF driver helper
[    2.118599] jh7110-sec 16000000.crypto: Unable to request sec_m dma channel in DMA channel
[    2.127746] jh7110-sec 16000000.crypto: Cannot initial dma chan
[    2.134578] usbcore: registered new interface driver usbhid
[    2.140729] usbhid: USB HID core driver
[    2.145228] usbcore: registered new interface driver snd-usb-audio
[    2.155381] NET: Registered PF_PACKET protocol family
[    2.160973] can: controller area network core
[    2.165896] NET: Registered PF_CAN protocol family
[    2.171188] can: raw protocol
[    2.174482] can: broadcast manager protocol
[    2.179102] can: netlink gateway - max_hops=1
[    2.184206] Bluetooth: RFCOMM TTY layer initialized
[    2.189630] Bluetooth: RFCOMM socket layer initialized
[    2.195334] Bluetooth: RFCOMM ver 1.11
[    2.199501] Bluetooth: BNEP (Ethernet Emulation) ver 1.3
[    2.205384] Bluetooth: BNEP filters: protocol multicast
[    2.211156] Bluetooth: BNEP socket layer initialized
[    2.216823] 9pnet: Installing 9P2000 support
[    2.221591] Key type dns_resolver registered
[    2.227079] Loading compiled-in X.509 certificates
[    2.268404] starfive_jh7110-pinctrl 13040000.gpio: SiFive GPIO chip registered 64 GPIOs
[    2.278023] starfive_jh7110-pinctrl 17020000.gpio: SiFive GPIO chip registered 4 GPIOs
[    2.287007] pl08xdmac 16008000.sec_dma: initialized 8 virtual memcpy channels
[    2.294910] pl08xdmac 16008000.sec_dma: initialized 16 virtual slave channels
[    2.304443] debugfs: Directory '16008000.sec_dma' with parent 'dmaengine' already present!
[    2.313591] pl08xdmac 16008000.sec_dma: DMA: PL080 rev0 at 0x16008000 irq 23
[    2.321646] ssp-pl022 10060000.spi: ARM PL022 driver for StarFive SoC platform, device ID: 0x00041022
[    2.331852] ssp-pl022 10060000.spi: mapped registers from 0x0000000010060000 to (____ptrval____)
[    2.341992] ssp-pl022 10060000.spi: Requested frequency: 10000000 Hz is unsupported,select by default 8250000 Hz
[    2.353615] ssp-pl022 10060000.spi: will use autosuspend for runtime pm, delay 100ms
[    2.363534] i2c 2-0045: Fixing up cyclic dependency with 295d0000.mipi
[    2.371039] seeed_panel 2-0045: Unknown Atmel firmware revision: 0x00
[    2.378361] i2c 2-0019: Fixing up cyclic dependency with 295d0000.mipi
[    2.386999] at24 5-0050: supply vcc not found, using dummy regulator
[    2.394835] at24 5-0050: 512 byte 24c04 EEPROM, writable, 16 bytes/write
[    2.404119] axp15060-regulator 5-0036: Register mipi_0p9 done! vol range:900 ~ 900 mV
[    2.414308] axp15060-regulator 5-0036: Register hdmi_1p8 done! vol range:1800 ~ 1800 mV
[    2.424634] axp15060-regulator 5-0036: Register hdmi_0p9 done! vol range:900 ~ 900 mV
[    2.434826] axp15060-regulator 5-0036: Register cpu_vdd done! vol range:500 ~ 1540 mV
[    2.444277] i2c 6-0010: Fixing up cyclic dependency with 19800000.vin_sysctl
[    2.452449] imx219 6-0010: supply VANA not found, using dummy regulator
[    2.459885] imx219 6-0010: supply VDIG not found, using dummy regulator
[    2.467256] imx219 6-0010: supply VDDL not found, using dummy regulator
[    2.482051] imx219 6-0010: failed to read chip id 219
[    2.487856] imx219: probe of 6-0010 failed with error -5
[    2.496313] pcie_plda 2b000000.pcie: host bridge /soc/pcie@2B000000 ranges:
[    2.504042] pcie_plda 2b000000.pcie:      MEM 0x0030000000..0x0037ffffff -> 0x0030000000
[    2.513013] pcie_plda 2b000000.pcie:      MEM 0x0900000000..0x093fffffff -> 0x0900000000
[    2.521995] ATR entry: 0x0940000000 -> 0x0000000000 [0x0010000000] (param: 0x000001)
[    2.530569] ATR entry: 0x0030000000 -> 0x0030000000 [0x0008000000] (param: 0x000000)
[    2.539134] ATR entry: 0x0900000000 -> 0x0900000000 [0x0040000000] (param: 0x000000)
[    2.894332] pcie_plda 2b000000.pcie: Port link up.
[    2.899776] pcie_plda 2b000000.pcie: PCI host bridge to bus 0000:00
[    2.906716] pci_bus 0000:00: root bus resource [bus 00-ff]
[    2.912768] pci_bus 0000:00: root bus resource [mem 0x30000000-0x37ffffff]
[    2.920368] pci_bus 0000:00: root bus resource [mem 0x900000000-0x93fffffff pref]
[    2.928661] pci 0000:00:00.0: [1556:1111] type 01 class 0x060400
[    2.935307] pci 0000:00:00.0: reg 0x10: [mem 0x00000000-0xffffffff 64bit pref]
[    2.943331] pci 0000:00:00.0: supports D1 D2
[    2.948053] pci 0000:00:00.0: PME# supported from D0 D1 D2 D3hot D3cold
[    2.958884] pci 0000:00:00.0: bridge configuration invalid ([bus 00-00]), reconfiguring
[    2.967871] pci 0000:01:00.0: [1106:3483] type 00 class 0x0c0330
[    2.974526] pci 0000:01:00.0: reg 0x10: [mem 0x00000000-0x00000fff 64bit]
[    2.982089] pci 0000:01:00.0: PME# supported from D0 D3cold
[    2.991592] pci_bus 0000:01: busn_res: [bus 01-ff] end is updated to 01
[    2.998930] pci 0000:00:00.0: BAR 0: no space for [mem size 0x100000000 64bit pref]
[    3.007400] pci 0000:00:00.0: BAR 0: failed to assign [mem size 0x100000000 64bit pref]
[    3.016255] pci 0000:00:00.0: BAR 8: assigned [mem 0x30000000-0x300fffff]
[    3.023738] pci 0000:01:00.0: BAR 0: assigned [mem 0x30000000-0x30000fff 64bit]
[    3.031831] pci 0000:00:00.0: PCI bridge to [bus 01]
[    3.037315] pci 0000:00:00.0:   bridge window [mem 0x30000000-0x300fffff]
[    3.044914] pci 0000:00:00.0: enabling device (0000 -> 0002)
[    3.051155] pci 0000:01:00.0: enabling device (0000 -> 0002)
[    3.057436] pci 0000:01:00.0: quirk_usb_early_handoff+0x0/0x9d4 took 12238 usecs
[    3.065829] xhci_hcd 0000:01:00.0: xHCI Host Controller
[    3.071616] xhci_hcd 0000:01:00.0: new USB bus registered, assigned bus number 1
[    3.080195] xhci_hcd 0000:01:00.0: hcc params 0x002841eb hci version 0x100 quirks 0x0000040000000890
[    3.090355] pcie_plda 2b000000.pcie: msi#0 address_hi 0x0 address_lo 0x190
[    3.098325] xhci_hcd 0000:01:00.0: xHCI Host Controller
[    3.104102] xhci_hcd 0000:01:00.0: new USB bus registered, assigned bus number 2
[    3.112292] xhci_hcd 0000:01:00.0: Host supports USB 3.0 SuperSpeed
[    3.119955] hub 1-0:1.0: USB hub found
[    3.124129] hub 1-0:1.0: 1 port detected
[    3.129524] hub 2-0:1.0: USB hub found
[    3.133699] hub 2-0:1.0: 4 ports detected
[    3.140954] pcie_plda 2c000000.pcie: host bridge /soc/pcie@2C000000 ranges:
[    3.148707] pcie_plda 2c000000.pcie:      MEM 0x0038000000..0x003fffffff -> 0x0038000000
[    3.157662] pcie_plda 2c000000.pcie:      MEM 0x0980000000..0x09bfffffff -> 0x0980000000
[    3.166655] ATR entry: 0x09c0000000 -> 0x0000000000 [0x0010000000] (param: 0x000001)
[    3.175220] ATR entry: 0x0038000000 -> 0x0038000000 [0x0008000000] (param: 0x000000)
[    3.183768] ATR entry: 0x0980000000 -> 0x0980000000 [0x0040000000] (param: 0x000000)
[    3.344283] usb usb2-port2: over-current condition
[    3.444304] usb 1-1: new high-speed USB device number 2 using xhci_hcd
[    3.504310] usb usb2-port4: over-current condition
[    3.614508] pcie_plda 2c000000.pcie: Port link down, exit.
[    3.634337] clk-starfive-jh7110-vout 295c0000.clock-controller: starfive JH7110 clk_vout init successfully.
[    3.655436] hub 1-1:1.0: USB hub found
[    3.656824] clk-starfive-jh7110-isp 19810000.clock-controller: starfive JH7110 clk_isp init successfully.
[    3.659813] hub 1-1:1.0: 4 ports detected
[    3.670789] dw_axi_dmac_platform 16050000.dma-controller: DesignWare AXI DMA Controller, 4 channels
[    3.685594] printk: console [ttyS0] disabled
[    3.710553] 10000000.serial: ttyS0 at MMIO 0x10000000 (irq = 17, base_baud = 1500000) is a 16550A
[    3.720407] printk: console [ttyS0] enabled
[    3.729214] printk: bootconsole [uart0] disabled
[    3.739447] jh7110-vin 19800000.vin_sysctl: stfcamss probe enter!
[    3.747568] jh7110-vin 19800000.vin_sysctl: stfcamss probe success!
[    3.756345] dwmmc_starfive 16010000.sdio0: IDMAC supports 32-bit address mode.
[    3.756951] jh7110-sec 16000000.crypto: will run requests pump with realtime priority
[    3.763667] dwmmc_starfive 16010000.sdio0: Using internal DMA controller.
[    3.772173] dwmmc_starfive 16020000.sdio1: IDMAC supports 32-bit address mode.
[    3.778325] dwmmc_starfive 16010000.sdio0: Version ID is 290a
[    3.778369] dwmmc_starfive 16010000.sdio0: DW MMC controller at irq 29,32 bit host data width,32 deep fifo
[    3.781261] jh7110-sec 16000000.crypto: Initialized
[    3.782357] starfive-i2s 120b0000.i2stx_4ch0:  designware: play supported
[    3.782367] starfive-i2s 120b0000.i2stx_4ch0: designware: i2s master mode supported
[    3.782549] sf-mipi-dphy-tx 295e0000.mipi-dphy: sf_dphy_probe begin
[    3.782560] sf-mipi-dphy-tx 295e0000.mipi-dphy: ===> sf_dphy_probe enter, 445
[    3.782696] sf-mipi-dphy-tx 295e0000.mipi-dphy: control ECO
[    3.782722] sf-mipi-dphy-tx 295e0000.mipi-dphy: supply mipi_1p8 not found, using dummy regulator
[    3.783012] sf-mipi-dphy-tx 295e0000.mipi-dphy: sf_dphy_probe end
[    3.783213] cdns-dsi 295d0000.mipi: dsi_sys_clk = 297000000
[    3.783455] cdns-dsi 295d0000.mipi: starfive dsi bind end
[    3.785637] dwmmc_starfive 16020000.sdio1: Using internal DMA controller.
[    3.785709] of_cfs_init
[    3.785744] of_cfs_init: OK
[    3.786268] starfive-pwmdac 100b0000.pwmdac: clk_apb0 = 49500000, clk_pwmdac_apb = 49500000, clk_pwmdac_core = 4068493
[    3.786774] cfg80211: Loading compiled-in X.509 certificates for regulatory database
[    3.791504] mmc_host mmc0: card is non-removable.
[    3.801153] dwmmc_starfive 16020000.sdio1: Version ID is 290a
[    3.906458] dwmmc_starfive 16020000.sdio1: DW MMC controller at irq 30,32 bit host data width,32 deep fifo
[    3.907275] cfg80211: Loaded X.509 cert 'sforshee: 00b28ddf47aef9cea7'
[    3.916211] mmc_host mmc1: card is polling.
[    3.925079] starfive soc:display-subsystem: bound 29400000.dc8200 (ops 0xffffffff80e75af8)
[    3.935166] innohdmi-starfive 29590000.hdmi: inno hdmi bind begin
[    3.941612] platform regulatory.0: Direct firmware load for regulatory.db failed with error -2
[    3.950277] cfg80211: failed to load regulatory.db
[    3.955907] innohdmi-starfive 29590000.hdmi: [drm:inno_hdmi_bind] registered Inno HDMI I2C bus driver success
[    3.966014] innohdmi-starfive 29590000.hdmi: HDMI&AUDIO register done.
[    3.972564] innohdmi-starfive 29590000.hdmi: inno hdmi bind end
[    3.978505] starfive soc:display-subsystem: bound 29590000.hdmi (ops 0xffffffff80e768a8)
[    3.986612] vs-simple-encoder soc:dsi-output: encoder_bind begin
[    3.992642] no panel, -517
[    3.995365] vs-simple-encoder soc:dsi-output: encoder_bind error
[    4.001374] starfive soc:display-subsystem: bound soc:dsi-output (ops 0xffffffff80e764f0)
[    4.010000] [drm] Initialized starfive 1.0.0 20191101 for soc:display-subsystem on minor 1
[    4.034249] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 400000Hz, actual 399193HZ div = 248)
[    4.144348] mmc_host mmc1: Bus speed (slot 0) = 198000000Hz (slot req 400000Hz, actual 399193HZ div = 248)
[    4.396890] mmc_host mmc1: Bus speed (slot 0) = 198000000Hz (slot req 50000000Hz, actual 49500000HZ div = 2)
[    4.406993] mmc1: new high speed SDXC card at address 59b4
[    4.413023] random: fast init done
[    4.417358] mmcblk1: mmc1:59b4 EC1S5 59.7 GiB
[    4.430503]  mmcblk1: p1 p2 p3
[    4.484331] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 300000Hz, actual 300000HZ div = 330)
[    4.924339] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 200000Hz, actual 200000HZ div = 495)
[    5.094347] usb 1-1.1: new low-speed USB device number 3 using xhci_hcd
[    5.243954] input: TK-FCP026 Series as /devices/platform/soc/2b000000.pcie/pci0000:00/0000:00:00.0/0000:01:00.0/usb1/1-1/1-1.1/1-1.1:1.0/0003:056E:1013.0001/input/input0
[    5.324734] hid-generic 0003:056E:1013.0001: input: USB HID v1.10 Keyboard [TK-FCP026 Series] on usb-0000:01:00.0-1.1/input0
[    5.343747] input: TK-FCP026 Series System Control as /devices/platform/soc/2b000000.pcie/pci0000:00/0000:00:00.0/0000:01:00.0/usb1/1-1/1-1.1/1-1.1:1.1/0003:056E:1013.0002/input/input1
[    5.374246] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 100000Hz, actual 100000HZ div = 990)
[    5.424563] input: TK-FCP026 Series Consumer Control as /devices/platform/soc/2b000000.pcie/pci0000:00/0000:00:00.0/0000:01:00.0/usb1/1-1/1-1.1/1-1.1:1.1/0003:056E:1013.0002/input/input2
[    5.441441] hid-generic 0003:056E:1013.0002: input: USB HID v1.10 Device [TK-FCP026 Series] on usb-0000:01:00.0-1.1/input1
[    6.084315] ALSA device list:
[    6.087335]   #0: Starfive-PWMDAC-Sound-Card
[    6.091659]   #1: Starfive-HDMI-Sound-Card
[    6.100590] Freeing unused kernel image (initmem) memory: 2188K
[    6.106909] Run /init as init process
[    6.110626]   with arguments:
[    6.110642]     /init
[    6.110655]   with environment:
[    6.110670]     HOME=/
[    6.110683]     TERM=linux
[    6.110697]     stmmaceth=chain_mode:1
[    6.110716]     selinux=0
[    7.089399] EXT4-fs (mmcblk1p3): mounted filesystem with ordered data mode. Opts: (null). Quota mode: disabled.
[    7.776963] systemd[1]: System time before build time, advancing clock.
[    7.863097] systemd[1]: systemd 251.2-5 running in system mode (+PAM +AUDIT +SELINUX +APPARMOR +IMA +SMACK +SECCOMP +GCRYPT -GNUTLS +OPENSSL +ACL +BLKID +CURL +ELFUTILS +FIDO2 +IDN2 -IDN +IPTC +KMOD +LIBCRYPTSETUP +LIBFDISK +PCRE2 -PWQUALITY -P11KIT -QRENCODE +TPM2 +BZIP2 +LZ4 +XZ +ZLIB +ZSTD -BPF_FRAMEWORK -XKBCOMMON +UTMP +SYSVINIT default-hierarchy=unified)
[    7.895329] systemd[1]: Detected architecture riscv64.
[    7.903523] systemd[1]: Hostname set to <starfive>.
[    8.433281] systemd[1]: Queued start job for default target Graphical Interface.
[    8.442977] systemd[1]: Created slice Slice /system/getty.
[    8.449336] systemd[1]: Created slice Slice /system/modprobe.
[    8.456514] systemd[1]: Created slice Slice /system/serial-getty.
[    8.463971] systemd[1]: Created slice Slice /system/systemd-fsck.
[    8.471207] systemd[1]: Created slice User and Session Slice.
[    8.478157] systemd[1]: Started Forward Password Requests to Wall Directory Watch.
[    8.487122] systemd[1]: Arbitrary Executable File Formats File System Automount Point was skipped because of a failed condition check (ConditionPathExists=/proc/sys/fs/binfmt_misc).
[    8.504660] systemd[1]: Reached target Local Integrity Protected Volumes.
[    8.512702] systemd[1]: Reached target Remote File Systems.
[    8.519576] systemd[1]: Reached target Slice Units.
[    8.525850] systemd[1]: Reached target Swaps.
[    8.531613] systemd[1]: Reached target Local Verity Protected Volumes.
[    8.539820] systemd[1]: Listening on Syslog Socket.
[    8.545907] systemd[1]: Listening on fsck to fsckd communication Socket.
[    8.553896] systemd[1]: Listening on initctl Compatibility Named Pipe.
[    8.567859] systemd[1]: Journal Audit Socket was skipped because of a failed condition check (ConditionSecurity=audit).
[    8.579756] systemd[1]: Listening on Journal Socket (/dev/log).
[    8.587021] systemd[1]: Listening on Journal Socket.
[    8.593386] systemd[1]: Listening on udev Control Socket.
[    8.599998] systemd[1]: Listening on udev Kernel Socket.
[    8.608392] systemd[1]: Mounting Huge Pages File System...
[    8.616435] systemd[1]: Mounting POSIX Message Queue File System...
[    8.625546] systemd[1]: Mounting Kernel Debug File System...
[    8.632460] systemd[1]: Kernel Trace File System was skipped because of a failed condition check (ConditionPathExists=/sys/kernel/tracing).
[    8.646608] systemd[1]: Create List of Static Device Nodes was skipped because of a failed condition check (ConditionFileNotEmpty=/lib/modules/5.15.0-starfive/modules.devname).
[    8.665578] systemd[1]: Starting Load Kernel Module configfs...
[    8.674147] systemd[1]: Starting Load Kernel Module drm...
[    8.682437] systemd[1]: Starting Load Kernel Module fuse...
[    8.688911] systemd[1]: File System Check on Root Device was skipped because of a failed condition check (ConditionPathIsReadWrite=!/).
[    8.705889] systemd[1]: Starting Journal Service...
[    8.716917] systemd[1]: Starting Load Kernel Modules...
[    8.725627] systemd[1]: Starting Remount Root and Kernel File Systems...
[    8.732846] systemd[1]: Repartition Root Disk was skipped because all trigger condition checks failed.
[    8.745743] systemd[1]: Starting Coldplug All udev Devices...
[    8.748138] EXT4-fs (mmcblk1p3): re-mounted. Opts: errors=remount-ro. Quota mode: disabled.
[    8.766284] systemd[1]: Mounted Huge Pages File System.
[    8.772985] systemd[1]: Mounted POSIX Message Queue File System.
[    8.780431] systemd[1]: Mounted Kernel Debug File System.
[    8.787459] systemd[1]: modprobe@configfs.service: Deactivated successfully.
[    8.795202] systemd[1]: Finished Load Kernel Module configfs.
[    8.809276] systemd[1]: modprobe@drm.service: Deactivated successfully.
[    8.817365] systemd[1]: Finished Load Kernel Module drm.
[    8.823873] systemd[1]: Started Journal Service.
[    8.866146] systemd-journald[253]: Received client request to flush runtime journal.
[    9.719973] vdec: loading out-of-tree module taints kernel.
[    9.728380] SUCCESS alloc_chrdev_region
[    9.729208] vdec 130a0000.vpu_dec: device init.
[    9.733434] cnm_jpu 13090000.jpu: init device.
[    9.738362] SUCCESS alloc_chrdev_region
[   10.324629] random: alsactl: uninitialized urandom read (4 bytes read)
[   10.950993] random: alsactl: uninitialized urandom read (4 bytes read)
[   11.384365] random: alsactl: uninitialized urandom read (4 bytes read)
[   11.389792] random: dbus-daemon: uninitialized urandom read (12 bytes read)
[   11.422177] random: avahi-daemon: uninitialized urandom read (4 bytes read)
[   12.224275] random: crng init done
[   12.227703] random: 2 urandom warning(s) missed due to ratelimiting
[   13.320969] starfive-eth-plat 16030000.ethernet eth0: PHY [stmmac-0:00] driver [YT8531 Gigabit Ethernet] (irq=POLL)
[   13.332100] starfive-eth-plat 16030000.ethernet eth0: Register MEM_TYPE_PAGE_POOL RxQ-0
[   13.344307] dwmac4: Master AXI performs fixed burst length
[   13.349871] starfive-eth-plat 16030000.ethernet eth0: No Safety Features support found
[   13.357899] starfive-eth-plat 16030000.ethernet eth0: IEEE 1588-2008 Advanced Timestamp supported
[   13.367295] starfive-eth-plat 16030000.ethernet eth0: configuring for phy/rgmii-id link mode
[   13.388888] starfive-eth-plat 16040000.ethernet eth1: PHY [stmmac-1:00] driver [YT8512B Ethernet] (irq=POLL)
[   13.399026] starfive-eth-plat 16040000.ethernet eth1: Register MEM_TYPE_PAGE_POOL RxQ-0
[   13.407375] dwmac4: Master AXI performs fixed burst length
[   13.412921] starfive-eth-plat 16040000.ethernet eth1: No Safety Features support found
[   13.420942] starfive-eth-plat 16040000.ethernet eth1: IEEE 1588-2008 Advanced Timestamp supported
[   13.456848] starfive-eth-plat 16040000.ethernet eth1: configuring for phy/rgmii-id link mode
[   13.468492] starfive-eth-plat 16040000.ethernet eth1: Link is Up - 100Mbps/Full - flow control off
[   13.501237] vs_gem_dumb_create size = 1000
[   13.505400] Allocated coherent memory, vaddr: 0xFFFFFFE0FEBFD2D8, paddr: 0x1012E5000
[   13.513153] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   13.943569] PVR_K:  412: RGX Firmware image 'rgx.fw.36.50.54.182' loaded
[   14.011651] PVR_K:  412: Shader binary image 'rgx.sh.36.50.54.182' loaded
[   14.022915] PVR_K:  412: X connected - (devID = 0)
[   14.251106] vs_gem_dumb_create size = 7e9000
[   14.256407] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFC20C0, paddr: 0x80200000
[   14.264086] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   14.306311] vs_gem_dumb_create size = 4000
[   14.310549] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFBEA80, paddr: 0x80108000
[   14.318227] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   14.323980] vs_gem_dumb_create size = 4000
[   14.328255] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFBEB60, paddr: 0x8010C000
[   14.335931] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   15.320413] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate rate 148500000 tmdsclk 148500000
[   15.429986] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->pixclock = 148500000
[   15.439744] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->tmdsclock = 148500000
[   15.449581] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->prediv = 1
[   15.458467] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->fbdiv = 99
[   15.467348] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->tmds_div_a = 1
[   15.476575] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->tmds_div_b = 1
[   15.485803] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->tmds_div_c = 1
[   15.495032] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->pclk_div_a = 1
[   15.504259] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->pclk_div_b = 2
[   15.513475] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->pclk_div_c = 2
[   15.522709] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->pclk_div_d = 2
[   15.531967] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->vco_div_5_en = 0
[   15.541378] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->fracdiv = 0
[   15.550352] innohdmi-starfive 29590000.hdmi: *******************************************************
[   15.559492] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->tmdsclock = 148500000
[   15.569414] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->prediv = 1
[   15.578387] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->fbdiv = 20
[   15.587363] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->postdiv = 1
[   15.596424] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->post_div_en = 3
[   15.605833] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->version = 3
[   34.484816] mipi_0p9: disabling
[   39.704348] usb 1-1.3: new low-speed USB device number 4 using xhci_hcd
[   39.855298] input: KYE ADNS6000 Optical Mouse as /devices/platform/soc/2b000000.pcie/pci0000:00/0000:00:00.0/0000:01:00.0/usb1/1-1/1-1.3/1-1.3:1.0/0003:0458:005E.0003/input/input3
[   39.871618] hid-generic 0003:0458:005E.0003: input: USB HID v1.10 Mouse [KYE ADNS6000 Optical Mouse] on usb-0000:01:00.0-1.3/input0
[   41.418339] systemd-journald[253]: Oldest entry in /var/log/journal/bd887d4196a5463aa4c948eb57286362/system.journal is older than the configured file retention duration (1month), suggesting rotation.
[   41.436358] systemd-journald[253]: /var/log/journal/bd887d4196a5463aa4c948eb57286362/system.journal: Journal header limits reached or header out-of-date, rotating.
[   68.635238] PVR_K:(Error):   412: DevmemSubAllocate: Failed! Error is PVRSRV_ERROR_DEVICEMEM_OUT_OF_DEVICE_VM. Allocation size: 0x0000000058 [1635]
[   68.648499] PVR_K:(Error):   412: RGXCreateHWRTDataSet: DevmemAllocate for FwHWRTDataCommon failed [1582]
[   68.658091] Unable to handle kernel paging request at virtual address ffffff8d60a00018
[   68.666024] Oops [#1]
[   68.668296] Modules linked in: jpu(O) venc(O) vdec(O)
[   68.673358] CPU: 1 PID: 412 Comm: X Tainted: G          `O      5.15.0-starfive #1
[   68.680928] Hardware name: StarFive VisionFive V2 (DT)
[   68.686064] epc : RGXDestroyHWRTDataSet+0x24/0xca
[   68.690776]  ra : PVRSRVBridgeRGXCreateHWRTDataSet+0x2ba/0xae8
[   68.696618] epc : ffffffff804b29da ra : ffffffff804e6ff6 sp : ffffffd0044eb920
[   68.703844]  gp : ffffffff815006b8 tp : ffffffe0c0f2bc00 t0 : 0000000000000040
[   68.711069]  t1 : 0000000000000000 t2 : 0000000000000000 s0 : ffffffd0044eb960
[   68.718294]  s1 : ffffffe0c49f8258 a0 : 0200000d60a00000 a1 : 000000000000009b
[   68.725520]  a2 : 0000000000000053 a3 : 0000000000000053 a4 : 0000000000000053
[   68.732745]  a5 : 68fdd6bf06041900 a6 : ffffffe0c89816d0 a7 : ffffffe0c89816f8
[   68.739971]  s2 : 0200000d60a00000 s3 : ffffffff815020a8 s4 : ffffffe0c49f8240
[   68.747197]  s5 : ffffffe0c49f8098 s6 : ffffffe0c49f80b8 s7 : 00000000000001c0
[   68.754422]  s8 : ffffffe0c49f8198 s9 : 0000000000000000 s10: ffffffe0c49fa000
[   68.761647]  s11: ffffffe0c49f8000 t3 : 0000000000000002 t4 : 0000000000000402
[   68.768871]  t5 : ffffffe0c6c1c200 t6 : ffffffe0c6c1c220
[   68.774180] status: 0000000200000120 badaddr: ffffff8d60a00018 cause: 000000000000000d
[   68.782102] [<ffffffff804b29da>] RGXDestroyHWRTDataSet+0x24/0xca
[   68.788107] [<ffffffff804e6ff6>] PVRSRVBridgeRGXCreateHWRTDataSet+0x2ba/0xae8
[   68.795238] [<ffffffff80482170>] BridgedDispatchKM+0x150/0x46a
[   68.801075] [<ffffffff8045fdbe>] PVRSRV_BridgeDispatchKM+0xb6/0x182
[   68.807345] [<ffffffff804216a4>] drm_ioctl_kernel+0x8c/0xd0
[   68.812921] [<ffffffff804219fe>] drm_ioctl+0x1c2/0x2f2
[   68.818060] [<ffffffff801372a4>] sys_ioctl+0x350/0x818
[   68.823200] [<ffffffff80003046>] ret_from_syscall+0x0/0x2
[   68.828619] ---[ end trace e8d874a9fd9d1c61 ]---
[   69.098425] PVR_K:  412: X disconnected - (devID = 0)
[   69.131289] vs_gem_dumb_create size = 1000
[   69.135428] Allocated coherent memory, vaddr: 0xFFFFFFE0FEC791D0, paddr: 0x10364E000
[   69.143166] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   69.192685] PVR_K:  742: X connected - (devID = 0)
[   69.205996] PVR_K:(Error):   742: DevmemSubAllocate: Failed! Error is PVRSRV_ERROR_DEVICEMEM_OUT_OF_DEVICE_VM. Allocation size: 0x0000010000 [1635]
[   69.219512] PVR_K:(Error):   742: DevmemSubAllocate: Failed! Error is PVRSRV_ERROR_DEVICEMEM_OUT_OF_DEVICE_VM. Allocation size: 0x0000008000 [1635]
[   69.233339] PVR_K:(Error):   742: DevmemSubAllocate: Failed! Error is PVRSRV_ERROR_DEVICEMEM_OUT_OF_DEVICE_VM. Allocation size: 0x0000008000 [1635]
[   69.309600] vs_gem_dumb_create size = 7e9000
[   69.314774] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFDE0C0, paddr: 0x80A00000
[   69.322434] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   69.368664] vs_gem_dumb_create size = 4000
[   69.373169] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFBEA80, paddr: 0x80108000
[   69.380848] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   69.386629] vs_gem_dumb_create size = 4000
[   69.391111] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFBEB60, paddr: 0x8010C000
[   69.398788] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   86.412915] vs_gem_dumb_create size = 7e9000
[   86.417576] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFC20C0, paddr: 0x80200000
[   86.425261] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   86.632491] vs_gem_dumb_create size = 7e9000
[   86.637352] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFFA0C0, paddr: 0x81200000
[   86.645034] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
root@starfive:~#

というわけで、SPLとU-Bootを更新すると、Image-69が起動できることを確認しました。

なお、Image-69で、apt upgradeかけたら、Xが起動しなくなりました・・・

64bit RISC-VコアのStarFive Vision Five 2が届いたけど標準提供Debianはうまく動かないバグあり


64bitのRISC-Vコアを4コア積んだSoC StarFive JH7110を使用したStarFive Vision Five2のクラウドファンディングが8月にあったのでRAM 4GBモデルを1個手配した。(ラズパイ4相当の性能が出るらしいRISC-VコアのSBC StarFive Vision Five 2のクラウドファンディングが進行中)

当初予定は2022年11月でしたが順調に遅れて、年越し間近の2022年12月29日に届きました。発送連絡は無く、突然の到着でした。

中はこんな感じ

中身のボードはこんな感じ

USBコネクタ 4個、HDMI、NIC 2ポートが同じ面についています。

裏面は、M.2 M-keyとmicroSDスロットです。

Vision Five 2に関するドキュメントは https://doc-en.rvspace.org/Doc_Center/visionfive_2.html にあります。

Debian OSの入手先は「Quick Start Guide」の「Flashing with Linux or Windows」に「Download the latest Debian image from: this link.」と記載されているように  https://debian.starfivetech.com/ からダウンロードできます。

2022/12/30時点では2022/12/20付けのImage-55、2022/12/26付けのImage-69が入手できます。

Quick Start Guideの「Logging into Debian」を見ると、HDMI画面が普通に出てくるように読めますが、実際のところ、標準出力は、GPIO端子のUARTシリアルコンソールとなっています。

このため、Xが起動するまでHDMI出力は真っ暗なままです。

しかも、新しいImage-69の方はX画面が出ません。Image-55であればX画面が出ます。

シリアルコンソールはUsing a USB to Serial ConverterFor Windows にある下記にしたがって結線して、115200 で接続。

うちで転がっていた大昔のPlannex NAS開発キットについてたTTL変換を久々に利用している。

Image-69のイメージを書き込んだmicroSDで起動してみると・・・

U-Boot SPL 2021.10`(Oct 31 2022`- 12:11:37 +0800)
DDR version: dc2e84f0.
Trying to boot from SPI

OpenSBI v1.0
 ``・           ・$x慄韶鞐X萎X・・蝠・蝠・・H   厰                      ・$<慙韶隶 戉・}}髫碯           鯏5R矜聰}燾濵・蝠       B炫     ・}モ驍5R矜矜浯z浯:浯碌 ・      ?浯矜5R矜}}驍磊モ炫     ・磊}}}モ磊モ驍}5R碯・・        r炫             ・・統驍}髱}}}}盾}}}}恕}}}}餤R`淫
酌 鞐_粟?典Rj・Platform Name   `鞐靹挨筧MX坑ive VisionFive V2
Platform Features     玻雕`medeleg
・衣clint-mswiCount    鞐漂jだ?宿喫A%"?
Platform Timer Device     > aclint-mtimer @ 400ppppHz
Platform Console Device   : uart8250
Platform HSM Device   鞐芽njjづ+
                                嵋
                                  U・
                                     TWガYH 虻 ---
Platform Shutdown Device  : ---
Firmware Base   ``鞐鞐X挨dL^0ppppp
Firmware Size   鞐鞐隶360 KB
Runtime SBI Version    ``H.3

Domain0 Name  ``鞐_霎鞣|'X・
                            W?+V
                                萌
                                  覃(*UH``>'・C・main0 HARTs   玻鞐X鞣x・b
                                                                          RbRbRb・jつ蟀+V
         蜂嶽㌦
               $$Hx     鞐雕`px00000000p2000000-0x00000000p200ffff (I)
Domain0 Region01   鞐鞐x00000鍵<0000ppp-0x000000004007ffff ()
Domain0 Region02   鞐鞐#dn00000pppp00-0xffffffffffffffff (R,W,X)
Domain0 Next Address    雕 px0000000p40200000
x000000<220pp00g1  `鞐鞐
Lomain0 Next Mode  ``鞐O萎S-mode
Domain0 SysReset    ``鞐 .Y・|!・
                                  ・*UHR・```隶霎l憊0
Boot HART 弟main   `鞐霍`尞ot
Boot HART Priv Version     v1.11
Boot HART Base ISA ``武瑁:`rv64imafdcbx
Boot HART ISA Gxtensions  : none
Boot HART PMp Count  ``雕`8
Boot HART pMP`・・W-W/$'HMN瘴ot HART PMP Allress Bits: 34
Boot HART MHpM Count   雕 2
°
  ・*U飯R・ρ$,愽韶鞐汰疏Bjい裨
                               ・*UHSQ・ρ$,犯0萎x0000000000b109


U-Boot 2021.10 (Oct 31 022`- 12:11:37 +0800), Build: jenkins-VF2_515_Branch_SDK_Release-10

CPU:  事64imacu
Model: StarFive VisionFive V2
DRAM: `4 GiB
MMC:   sdio0@16010000: 0, sdio1@16020000:`0
Loading Environment from SPIFlash... SF: Detected gd25lq128 with page size 256 Bytes, erase size 4 KiB, 逸tal 16 MiB
*** Warning - bad CRC,`using default environment

StarFive EEPROM format v2

--------EEPROM INFO--------
Vendor : StarFive Technology Co., Ltd.
Product full SN: VF7110A1-2249-D004E00p-00000617
data version: 0x2
PCB 劫vision: 0xa1
BOM revision: A
Ethernet MAC0 address: 6c:cf:39:00:18:2f
Ethernet MAC1 address: 6c:cf:39:00:18:30
--------EEPROM INFO--------

In:   `serial@10000000
ナコ  熈ラ・リ 怯ーーーーーーーut:  `・・X 怯0000ppp
ヘ・褌コ モ鴕・ヨ鴣鴆鏆鴕・ヨイ
ホ襁コ   襁隹コ 襁韃襁タアカーウーーーーャ 襁雎コ 襁韃襁タアカーエーーーー
鴟肛  鴟鴆ⅴ 」ーャ マヒ
澵羈 鴣 脉褓・蒟肄
跣・蒟肄 ア
糀・瀅蒟 跪碯・蒟肄 ア
テ碚ァ・・粮・・蒟肄
ニ硅・・ ・砌 ァッ糀・ッⅷョ
ネ鴟 碚・・・ ・ 磆糀・コ  ー
テ碚ァ・・粮・・蒟肄
ノ瀇・鰀 褓・褓・踉・ 澵羈 ョョョ
」」 ラ碪鵫鰀コ ノⅱ 蓊 褸肄裝・アーエクオキカ 糴・ュ 聶・
」」 ノ鮻・ 鴃・蓊 栁 ス アーエクオキク ス ーーーイ
」」 ナ・コ 「糀・イ「 ⅰ・蒟跌鮱・
鴟肛  鴟鴆ⅴ 」ーャ マヒ
澵羈 鴣 脉褓・蒟肄
モ聶・鴃・澵・アコイョョョ
ニ・鮏 ッ糀・ッ褸鴃ッ褸鴃ョ胥鮻
メ襁褻鴃・跌・コ ッ糀・ッ褸鴃ッ褸鴃ョ胥鮻
クカウ 糴・砌 鴃 オ 炫 ィアカク ヒ鯆ッ
ユュツ・・淲ⅶ
アコ      ト裘鱆・ヌホユッフ鴃 糀・ッ・オョアオョーュ碪跌
イコ      ト裘鱆・ヌホユッフ鴃 糀・ッ・オョアオョーュ碪跌 ィ 襁ゥ
ナⅵ褪 肛・肄コ

 not found
U-Boot menu
1:      Debian GNU/Linux bookworm/sid 5.15.0-starfive
2:      Debian GNU/Linux bookworm/sid 5.15.0-starfive (rescue target)
Enter choice: 1
1:      Debian GNU/Linux bookworm/sid 5.15.0-starfive
Retrieving file: /boot/initrd.img-5.15.0-starfive
9684944 bytes read in 409 ms (22.6 MiB/s)
Retrieving file: /boot/vmlinuz-5.15.0-starfive
8015160 bytes read in 341 ms (22.4 MiB/s)
append: root=/dev/mmcblk1p3 root=/dev/mmcblk1p3 rw console=tty0 console=ttyS0,115200 earlycon rootwait stmmaceth=chain_mode:1 selinux=0
Retrieving file: /boot/dtbs/starfive/starfive_visionfive2.dtb
Failed to load '/boot/dtbs/starfive/starfive_visionfive2.dtb'
kernel_comp_addr_r or kernel_comp_size is not provided!
2:      Debian GNU/Linux bookworm/sid 5.15.0-starfive (rescue target)
Retrieving file: /boot/initrd.img-5.15.0-starfive
9684944 bytes read in 410 ms (22.5 MiB/s)
Retrieving file: /boot/vmlinuz-5.15.0-starfive
8015160 bytes read in 342 ms (22.4 MiB/s)
append: root=/dev/mmcblk1p3 root=/dev/mmcblk1p3 rw console=tty0 console=ttyS0,115200 earlycon rootwait stmmaceth=chain_mode:1 selinux=0 single
Retrieving file: /boot/dtbs/starfive/starfive_visionfive2.dtb
Failed to load '/boot/dtbs/starfive/starfive_visionfive2.dtb'
kernel_comp_addr_r or kernel_comp_size is not provided!
SCRIPT FAILED:`continuing...
libfdt fdt_check_header(): FDT_ERR_BADMAGIC
Card did not respond to voltage select! : -110
** Unable to read file ubootefi.var **
Failed to load EFI variables
Scanning mmc 1:3...
libfdt fdt_check_header(): FDT_ERR_BADMAGIC
ethernet@16030000 Waiting for PHY auto negotiation to complete......... TIMEOUT !
phy_startup() failed: -110FAILED: -110ethernet@1604000p Waiting for PHY auto negotiation to complete.... done
BOOTP broadcast 1
DHCP client bound to address 192.168.1.135 (9 ms)
Using ethernet@16040000 峨vice
TFTP from server 192.168.1.1; our IP address is 192.168.1.135
Filename 'boot.scr.uimg'.
Load address: 0x88100000
Loading: *
TFTP server died; starting again
BOOTP broadcast 1
DHCP client bound to address 192.168.1.135 (5 ms)
Using ethernet@16040000`"evice
TFTP`from server 192.168.1.1; our IP X屋ess is 192.168.1.135
Filename 'boot.scr.uimg'.
Load address: 0x44000000
\oading: *
TFTP server died; starting again
StarFive #

うーん・・・起動に失敗してますね。

2023/01/12追記:Image-69で起動が失敗する件は「StarFive Vision Five 2の2022年12月出荷分を使うには面倒くさい手順が必要」で解消できます。

Image-55を書き込んで起動してみます。

Type-C PD電源を繋ぐと12Vで給電されました。秋月で売ってる5.1V3.8Aアダプタでも動きました。

ログインは「root」、パスワードは「starfive」です。

Image-55で起動した場合のdmesg

root@starfive:~# dmesg
[    0.000000] Linux version 5.15.0-starfive (sw_buildbot@mdcsw02) (riscv64-unknown-linux-gnu-gcc (GCC) 10.2.0, GNU ld (GNU Binutils) 2.35) #1 SMP Fri Nov 11 06:58:52 EST 2022
[    0.000000] OF: fdt: Ignoring memory range 0x40000000 - 0x40200000
[    0.000000] Machine model: StarFive VisionFive V2
[    0.000000] earlycon: uart0 at MMIO32 0x0000000010000000 (options '115200')
[    0.000000] printk: bootconsole [uart0] enabled
[    0.000000] efi: UEFI not found.
[    0.000000] Reserved memory: created CMA memory pool at 0x0000000080000000, size 512 MiB
[    0.000000] OF: reserved mem: initialized node linux,cma, compatible id shared-dma-pool
[    0.000000] Zone ranges:
[    0.000000]   DMA32    [mem 0x0000000040200000-0x00000000ffffffff]
[    0.000000]   Normal   [mem 0x0000000100000000-0x000000013fffffff]
[    0.000000] Movable zone start for each node
[    0.000000] Early memory node ranges
[    0.000000]   node   0: [mem 0x0000000040200000-0x00000000c010ffff]
[    0.000000]   node   0: [mem 0x00000000c0110000-0x00000000c01fffff]
[    0.000000]   node   0: [mem 0x00000000c0200000-0x000000013fffffff]
[    0.000000] Initmem setup node 0 [mem 0x0000000040200000-0x000000013fffffff]
[    0.000000] SBI specification v0.3 detected
[    0.000000] SBI implementation ID=0x1 Version=0x10000
[    0.000000] SBI TIME extension detected
[    0.000000] SBI IPI extension detected
[    0.000000] SBI RFENCE extension detected
[    0.000000] SBI v0.2 HSM extension detected
[    0.000000] CPU with hartid=0 is not available
[    0.000000] CPU with hartid=0 is not available
[    0.000000] riscv: ISA extensions acdfim
[    0.000000] riscv: ELF capabilities acdfim
[    0.000000] percpu: Embedded 17 pages/cpu s31528 r8192 d29912 u69632
[    0.000000] pcpu-alloc: s31528 r8192 d29912 u69632 alloc=17*4096
[    0.000000] pcpu-alloc: [0] 0 [0] 1 [0] 2 [0] 3
[    0.000000] Built 1 zonelists, mobility grouping on.  Total pages: 1033735
[    0.000000] Kernel command line: root=/dev/mmcblk1p3 rw console=tty0 console=ttyS0,115200 earlycon rootwait stmmaceth=chain_mode:1 selinux=0
[    0.000000] Unknown command line parameters: stmmaceth=chain_mode:1 selinux=0
[    0.000000] Dentry cache hash table entries: 524288 (order: 10, 4194304 bytes, linear)
[    0.000000] Inode-cache hash table entries: 262144 (order: 9, 2097152 bytes, linear)
[    0.000000] mem auto-init: stack:off, heap alloc:off, heap free:off
[    0.000000] software IO TLB: mapped [mem 0x00000000fbfff000-0x00000000fffff000] (64MB)
[    0.000000] Memory: 3451376K/4192256K available (9735K kernel code, 4976K rwdata, 4096K rodata, 2191K init, 399K bss, 216592K reserved, 524288K cma-reserved)
[    0.000000] SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=4, Nodes=1
[    0.000000] rcu: Hierarchical RCU implementation.
[    0.000000] rcu:     RCU restricting CPUs from NR_CPUS=8 to nr_cpu_ids=4.
[    0.000000] rcu:     RCU debug extended QS entry/exit.
[    0.000000]  Tracing variant of Tasks RCU enabled.
[    0.000000] rcu: RCU calculated value of scheduler-enlistment delay is 10 jiffies.
[    0.000000] rcu: Adjusting geometry for rcu_fanout_leaf=16, nr_cpu_ids=4
[    0.000000] NR_IRQS: 64, nr_irqs: 64, preallocated irqs: 0
[    0.000000] CPU with hartid=0 is not available
[    0.000000] riscv-intc: unable to find hart id for /cpus/cpu@0/interrupt-controller
[    0.000000] riscv-intc: 64 local interrupts mapped
[    0.000000] plic: plic@c000000: mapped 136 interrupts with 4 handlers for 9 contexts.
[    0.000000] random: get_random_bytes called from start_kernel+0x4d0/0x6e2 with crng_init=0
[    0.000000] riscv_timer_init_dt: Registering clocksource cpuid [0] hartid [4]
[    0.000000] clocksource: riscv_clocksource: mask: 0xffffffffffffffff max_cycles: 0x1d854df40, max_idle_ns: 881590404240 ns
[    0.000001] sched_clock: 64 bits at 4MHz, resolution 250ns, wraps every 2199023255500ns
[    0.008951] clocksource: timer@13050000.ch0: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.020261] clocksource: timer@13050000.ch1: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.031576] clocksource: timer@13050000.ch2: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.042886] clocksource: timer@13050000.ch3: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.054338] Console: colour dummy device 80x25
[    0.060268] printk: console [tty0] enabled
[    0.064812] Calibrating delay loop (skipped), value calculated using timer frequency.. 8.00 BogoMIPS (lpj=40000)
[    0.076021] pid_max: default: 32768 minimum: 301
[    0.081254] Mount-cache hash table entries: 8192 (order: 4, 65536 bytes, linear)
[    0.089480] Mountpoint-cache hash table entries: 8192 (order: 4, 65536 bytes, linear)
[    0.099361] ASID allocator disabled
[    0.103295] rcu: Hierarchical SRCU implementation.
[    0.108721] EFI services will not be available.
[    0.114054] smp: Bringing up secondary CPUs ...
[    0.120457] smp: Brought up 1 node, 4 CPUs
[    0.126075] devtmpfs: initialized
[    0.135754] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604462750000 ns
[    0.146600] futex hash table entries: 1024 (order: 4, 65536 bytes, linear)
[    0.166989] pinctrl core: initialized pinctrl subsystem
[    0.173535] NET: Registered PF_NETLINK/PF_ROUTE protocol family
[    0.180666] cpuidle: using governor menu
[    0.201831] platform 29400000.dc8200: Fixing up cyclic dependency with soc:rgb-output
[    0.210774] platform soc:dsi-output: Fixing up cyclic dependency with 29400000.dc8200
[    0.219803] platform 295d0000.mipi: Fixing up cyclic dependency with soc:dsi-output
[    0.228563] platform 29590000.hdmi: Fixing up cyclic dependency with 29400000.dc8200
[    0.246590] HugeTLB registered 1.00 GiB page size, pre-allocated 0 pages
[    0.253988] HugeTLB registered 2.00 MiB page size, pre-allocated 0 pages
[    0.264114] vgaarb: loaded
[    0.267293] SCSI subsystem initialized
[    0.271540] libata version 3.00 loaded.
[    0.271686] usbcore: registered new interface driver usbfs
[    0.277769] usbcore: registered new interface driver hub
[    0.283635] usbcore: registered new device driver usb
[    0.289270] mc: Linux media interface: v0.10
[    0.293981] videodev: Linux video capture interface: v2.00
[    0.300191] Advanced Linux Sound Architecture Driver Initialized.
[    0.307205] Bluetooth: Core ver 2.22
[    0.311174] NET: Registered PF_BLUETOOTH protocol family
[    0.317014] Bluetooth: HCI device and connection manager initialized
[    0.324011] Bluetooth: HCI socket layer initialized
[    0.329379] Bluetooth: L2CAP socket layer initialized
[    0.334950] Bluetooth: SCO socket layer initialized
[    0.340680] clocksource: Switched to clocksource riscv_clocksource
[    0.353211] NET: Registered PF_INET protocol family
[    0.359048] IP idents hash table entries: 65536 (order: 7, 524288 bytes, linear)
[    0.370394] tcp_listen_portaddr_hash hash table entries: 2048 (order: 4, 81920 bytes, linear)
[    0.379897] TCP established hash table entries: 32768 (order: 6, 262144 bytes, linear)
[    0.388975] TCP bind hash table entries: 32768 (order: 8, 1048576 bytes, linear)
[    0.398232] TCP: Hash tables configured (established 32768 bind 32768)
[    0.405693] UDP hash table entries: 2048 (order: 5, 196608 bytes, linear)
[    0.413368] UDP-Lite hash table entries: 2048 (order: 5, 196608 bytes, linear)
[    0.421739] NET: Registered PF_UNIX/PF_LOCAL protocol family
[    0.428445] RPC: Registered named UNIX socket transport module.
[    0.434983] RPC: Registered udp transport module.
[    0.440153] RPC: Registered tcp transport module.
[    0.445335] RPC: Registered tcp NFSv4.1 backchannel transport module.
[    0.452999] PCI: CLS 0 bytes, default 64
[    0.457838] Initialise system trusted keyrings
[    0.462904] workingset: timestamp_bits=62 max_order=20 bucket_order=0
[    0.463103] Unpacking initramfs...
[    0.474979] NFS: Registering the id_resolver key type
[    0.480567] Key type id_resolver registered
[    0.485205] Key type id_legacy registered
[    0.489715] nfs4filelayout_init: NFSv4 File Layout Driver Registering...
[    0.497124] nfs4flexfilelayout_init: NFSv4 Flexfile Layout Driver Registering...
[    0.505333] ntfs: driver 2.1.32 [Flags: R/W].
[    0.510544] fuse: init (API version 7.34)
[    0.546191] NET: Registered PF_ALG protocol family
[    0.551521] Key type asymmetric registered
[    0.556040] Asymmetric key parser 'x509' registered
[    0.561512] Block layer SCSI generic (bsg) driver version 0.4 loaded (major 249)
[    0.569665] io scheduler mq-deadline registered
[    0.574683] io scheduler kyber registered
[    0.580841] start plist test
[    0.584361] end plist test
[    0.663781] clk-starfive-jh7110 13020000.clock-controller: starfive JH7110 clkgen init successfully.
[    0.675015] L2CACHE: DataError @ 0x00000000.08040110
[    0.680559] L2CACHE: DataFail @ 0x00000000.08040140
[    0.686063] L2CACHE: No. of Banks in the cache: 8
[    0.691275] L2CACHE: No. of ways per bank: 16
[    0.696083] L2CACHE: Sets per bank: 256
[    0.700317] L2CACHE: Bytes per cache block: 64
[    0.705263] L2CACHE: Index of the largest way enabled: 15
[    0.711557] jh7110-pmu 17030000.power-controller: registered 8 power domains
[    0.778505] Serial: 8250/16550 driver, 6 ports, IRQ sharing disabled
[    0.798718] @@#########################@@
[    0.841091] @@ dev ptr:ffffffe0bfee0000/1500/1
[    0.846243] PVR_K:  1: Read BVNC 36.50.54.182 from HW device registers
[    0.853536] PVR_K:  1: RGX Device registered BVNC 36.50.54.182 with 1 core in the system
[    0.863719] [drm] Initialized pvr 1.17.6210866 20170530 for 18000000.gpu on minor 0
[    0.882617] loop: module loaded
[    0.888040] libphy: Fixed MDIO Bus: probed
[    0.894178] CAN device driver interface
[    0.899029] starfive-eth-plat 16030000.ethernet: force_sf_dma_mode is ignored if force_thresh_dma_mode is set.
[    0.910539] starfive-eth-plat 16030000.ethernet: User ID: 0x41, Synopsys ID: 0x52
[    0.918854] starfive-eth-plat 16030000.ethernet:     DWMAC4/5
[    0.924950] starfive-eth-plat 16030000.ethernet: DMA HW capability register supported
[    0.933612] starfive-eth-plat 16030000.ethernet: RX Checksum Offload Engine supported
[    0.942293] starfive-eth-plat 16030000.ethernet: Wake-Up On Lan supported
[    0.949784] starfive-eth-plat 16030000.ethernet: TSO supported
[    0.956250] starfive-eth-plat 16030000.ethernet: Enable RX Mitigation via HW Watchdog Timer
[    0.965505] starfive-eth-plat 16030000.ethernet: Enabled Flow TC (entries=1)
[    0.973305] starfive-eth-plat 16030000.ethernet: TSO feature enabled
[    0.980318] starfive-eth-plat 16030000.ethernet: Using 40 bits DMA width
[    1.124750] Freeing initrd memory: 9456K
[    1.384601] libphy: stmmac: probed
[    1.388379] YT8531 Gigabit Ethernet stmmac-0:00: attached PHY driver (mii_bus:phy_addr=stmmac-0:00, irq=POLL)
[    1.399339] YT8531 Gigabit Ethernet stmmac-0:01: attached PHY driver (mii_bus:phy_addr=stmmac-0:01, irq=POLL)
[    1.411585] starfive-eth-plat 16040000.ethernet: force_sf_dma_mode is ignored if force_thresh_dma_mode is set.
[    1.423012] starfive-eth-plat 16040000.ethernet: User ID: 0x41, Synopsys ID: 0x52
[    1.431295] starfive-eth-plat 16040000.ethernet:     DWMAC4/5
[    1.437346] starfive-eth-plat 16040000.ethernet: DMA HW capability register supported
[    1.445989] starfive-eth-plat 16040000.ethernet: RX Checksum Offload Engine supported
[    1.454632] starfive-eth-plat 16040000.ethernet: Wake-Up On Lan supported
[    1.462120] starfive-eth-plat 16040000.ethernet: TSO supported
[    1.468551] starfive-eth-plat 16040000.ethernet: Enable RX Mitigation via HW Watchdog Timer
[    1.477783] starfive-eth-plat 16040000.ethernet: Enabled Flow TC (entries=1)
[    1.485565] starfive-eth-plat 16040000.ethernet: TSO feature enabled
[    1.492576] starfive-eth-plat 16040000.ethernet: Using 40 bits DMA width
[    1.751521] libphy: stmmac: probed
[    1.755297] YT8512B Ethernet stmmac-1:00: attached PHY driver (mii_bus:phy_addr=stmmac-1:00, irq=POLL)
[    1.765604] YT8512B Ethernet stmmac-1:03: attached PHY driver (mii_bus:phy_addr=stmmac-1:03, irq=POLL)
[    1.777445] Intel(R) Wireless WiFi driver for Linux
[    1.784774] cdns3-starfive 10210000.usbdrd: usb mode 2 2.0 probe success
[    1.792913] usbcore: registered new interface driver uas
[    1.798823] usbcore: registered new interface driver usb-storage
[    1.821012] starfive-rtc 17040000.rtc: registered as rtc0
[    1.826978] starfive-rtc 17040000.rtc: setting system clock to 2001-01-01T00:00:00 UTC (978307200)
[    1.837020] i2c_dev: i2c /dev entries driver
[    1.842173] usbcore: registered new interface driver uvcvideo
[    1.849628] starfive-wdt 13070000.wdog: Heartbeat: timeout=15, count/2=180000000 (0aba9500)
[    1.859373] Bluetooth: HCI UART driver ver 2.3
[    1.864298] Bluetooth: HCI UART protocol H4 registered
[    1.870170] starfive-cpufreq soc:starfive,jh7110-cpufreq: Failed to get regulator for cpu!
[    1.879313] starfive-cpufreq soc:starfive,jh7110-cpufreq: Failed to init starfive cpu dvfs info
[    1.889570] cpuidle-riscv-sbi: idle driver registered for all CPUs
[    1.896727] sdhci: Secure Digital Host Controller Interface driver
[    1.903568] sdhci: Copyright(c) Pierre Ossman
[    1.908398] Synopsys Designware Multimedia Card Interface Driver
[    1.915320] sdhci-pltfm: SDHCI platform and OF driver helper
[    1.922343] jh7110-sec 16000000.crypto: Unable to request sec_m dma channel in DMA channel
[    1.931491] jh7110-sec 16000000.crypto: Cannot initial dma chan
[    1.938323] usbcore: registered new interface driver usbhid
[    1.944501] usbhid: USB HID core driver
[    1.948990] usbcore: registered new interface driver snd-usb-audio
[    1.958869] NET: Registered PF_PACKET protocol family
[    1.964489] can: controller area network core
[    1.969410] NET: Registered PF_CAN protocol family
[    1.974720] can: raw protocol
[    1.977994] can: broadcast manager protocol
[    1.982641] can: netlink gateway - max_hops=1
[    1.987755] Bluetooth: RFCOMM TTY layer initialized
[    1.993184] Bluetooth: RFCOMM socket layer initialized
[    1.998872] Bluetooth: RFCOMM ver 1.11
[    2.003035] Bluetooth: BNEP (Ethernet Emulation) ver 1.3
[    2.008890] Bluetooth: BNEP filters: protocol multicast
[    2.014674] Bluetooth: BNEP socket layer initialized
[    2.020319] 9pnet: Installing 9P2000 support
[    2.025103] Key type dns_resolver registered
[    2.030602] Loading compiled-in X.509 certificates
[    2.072105] starfive_jh7110-pinctrl 13040000.gpio: SiFive GPIO chip registered 64 GPIOs
[    2.081740] starfive_jh7110-pinctrl 17020000.gpio: SiFive GPIO chip registered 4 GPIOs
[    2.090717] pl08xdmac 16008000.sec_dma: initialized 8 virtual memcpy channels
[    2.098603] pl08xdmac 16008000.sec_dma: initialized 16 virtual slave channels
[    2.107989] debugfs: Directory '16008000.sec_dma' with parent 'dmaengine' already present!
[    2.117159] pl08xdmac 16008000.sec_dma: DMA: PL080 rev0 at 0x16008000 irq 22
[    2.127395] pcie_plda 2b000000.pcie: host bridge /soc/pcie@2B000000 ranges:
[    2.135184] pcie_plda 2b000000.pcie:      MEM 0x0030000000..0x0037ffffff -> 0x0030000000
[    2.144142] pcie_plda 2b000000.pcie:      MEM 0x0900000000..0x093fffffff -> 0x0900000000
[    2.153125] ATR entry: 0x0940000000 -> 0x0000000000 [0x0010000000] (param: 0x000001)
[    2.161696] ATR entry: 0x0030000000 -> 0x0030000000 [0x0008000000] (param: 0x000000)
[    2.170244] ATR entry: 0x0900000000 -> 0x0900000000 [0x0040000000] (param: 0x000000)
[    2.520712] pcie_plda 2b000000.pcie: Port link up.
[    2.526140] pcie_plda 2b000000.pcie: PCI host bridge to bus 0000:00
[    2.533078] pci_bus 0000:00: root bus resource [bus 00-ff]
[    2.539131] pci_bus 0000:00: root bus resource [mem 0x30000000-0x37ffffff]
[    2.546733] pci_bus 0000:00: root bus resource [mem 0x900000000-0x93fffffff pref]
[    2.555028] pci 0000:00:00.0: [1556:1111] type 01 class 0x078000
[    2.561674] pci 0000:00:00.0: reg 0x10: [mem 0x00000000-0xffffffff 64bit pref]
[    2.569702] pci 0000:00:00.0: supports D1 D2
[    2.574420] pci 0000:00:00.0: PME# supported from D0 D1 D2 D3hot D3cold
[    2.585107] pci 0000:00:00.0: bridge configuration invalid ([bus 00-00]), reconfiguring
[    2.594081] pci 0000:01:00.0: [1106:3483] type 00 class 0x0c0330
[    2.600737] pci 0000:01:00.0: reg 0x10: [mem 0x00000000-0x00000fff 64bit]
[    2.608302] pci 0000:01:00.0: PME# supported from D0 D3cold
[    2.617633] pci_bus 0000:01: busn_res: [bus 01-ff] end is updated to 01
[    2.624971] pci 0000:00:00.0: BAR 0: no space for [mem size 0x100000000 64bit pref]
[    2.633439] pci 0000:00:00.0: BAR 0: failed to assign [mem size 0x100000000 64bit pref]
[    2.642301] pci 0000:00:00.0: BAR 8: assigned [mem 0x30000000-0x300fffff]
[    2.649786] pci 0000:01:00.0: BAR 0: assigned [mem 0x30000000-0x30000fff 64bit]
[    2.657883] pci 0000:00:00.0: PCI bridge to [bus 01]
[    2.663367] pci 0000:00:00.0:   bridge window [mem 0x30000000-0x300fffff]
[    2.670970] pci 0000:00:00.0: enabling device (0000 -> 0002)
[    2.677211] pci 0000:01:00.0: enabling device (0000 -> 0002)
[    2.683495] pci 0000:01:00.0: quirk_usb_early_handoff+0x0/0x9d4 took 12241 usecs
[    2.691888] xhci_hcd 0000:01:00.0: xHCI Host Controller
[    2.697671] xhci_hcd 0000:01:00.0: new USB bus registered, assigned bus number 1
[    2.706274] xhci_hcd 0000:01:00.0: hcc params 0x002841eb hci version 0x100 quirks 0x0000040000000890
[    2.716459] pcie_plda 2b000000.pcie: msi#0 address_hi 0x0 address_lo 0x190
[    2.724442] xhci_hcd 0000:01:00.0: xHCI Host Controller
[    2.730218] xhci_hcd 0000:01:00.0: new USB bus registered, assigned bus number 2
[    2.738398] xhci_hcd 0000:01:00.0: Host supports USB 3.0 SuperSpeed
[    2.746064] hub 1-0:1.0: USB hub found
[    2.750240] hub 1-0:1.0: 1 port detected
[    2.755621] hub 2-0:1.0: USB hub found
[    2.759798] hub 2-0:1.0: 4 ports detected
[    2.766996] pcie_plda 2c000000.pcie: host bridge /soc/pcie@2C000000 ranges:
[    2.774742] pcie_plda 2c000000.pcie:      MEM 0x0038000000..0x003fffffff -> 0x0038000000
[    2.783700] pcie_plda 2c000000.pcie:      MEM 0x0980000000..0x09bfffffff -> 0x0980000000
[    2.792685] ATR entry: 0x09c0000000 -> 0x0000000000 [0x0010000000] (param: 0x000001)
[    2.801252] ATR entry: 0x0038000000 -> 0x0038000000 [0x0008000000] (param: 0x000000)
[    2.809802] ATR entry: 0x0980000000 -> 0x0980000000 [0x0040000000] (param: 0x000000)
[    2.970743] usb usb2-port2: over-current condition
[    3.070737] usb 1-1: new high-speed USB device number 2 using xhci_hcd
[    3.130747] usb usb2-port4: over-current condition
[    3.253597] hub 1-1:1.0: USB hub found
[    3.257984] hub 1-1:1.0: 4 ports detected
[    3.260710] pcie_plda 2c000000.pcie: Port link down, exit.
[    3.282096] clk-starfive-jh7110-vout 295c0000.clock-controller: starfive JH7110 clk_vout init successfully.
[    3.304537] clk-starfive-jh7110-isp 19810000.clock-controller: starfive JH7110 clk_isp init successfully.
[    3.315710] dw_axi_dmac_platform 16050000.dma-controller: DesignWare AXI DMA Controller, 4 channels
[    3.326746] printk: console [ttyS0] disabled
[    3.351719] 10000000.serial: ttyS0 at MMIO 0x10000000 (irq = 16, base_baud = 1500000) is a 16550A
[    3.361568] printk: console [ttyS0] enabled
[    3.370359] printk: bootconsole [uart0] disabled
[    3.381804] i2c 2-0045: Fixing up cyclic dependency with 295d0000.mipi
[    3.389408] at24 5-0050: supply vcc not found, using dummy regulator
[    3.396656] at24 5-0050: 512 byte 24c04 EEPROM, writable, 16 bytes/write
[    3.405372] axp15060-regulator 5-0036: Register mipi_0p9 done! vol range:900 ~ 900 mV
[    3.414787] axp15060-regulator 5-0036: Register hdmi_1p8 done! vol range:1800 ~ 1800 mV
[    3.424389] axp15060-regulator 5-0036: Register hdmi_0p9 done! vol range:900 ~ 900 mV
[    3.433838] axp15060-regulator 5-0036: Register cpu_vdd done! vol range:500 ~ 1540 mV
[    3.442572] i2c 6-0010: Fixing up cyclic dependency with 19800000.vin_sysctl
[    3.450095] imx219 6-0010: supply VANA not found, using dummy regulator
[    3.456883] imx219 6-0010: supply VDIG not found, using dummy regulator
[    3.463597] imx219 6-0010: supply VDDL not found, using dummy regulator
[    3.477772] imx219 6-0010: failed to read chip id 219
[    3.483082] imx219: probe of 6-0010 failed with error -5
[    3.488714] jh7110-vin 19800000.vin_sysctl: stfcamss probe enter!
[    3.496856] jh7110-vin 19800000.vin_sysctl: stfcamss probe success!
[    3.505556] dwmmc_starfive 16010000.sdio0: IDMAC supports 32-bit address mode.
[    3.505942] jh7110-sec 16000000.crypto: Unbalanced pm_runtime_enable!
[    3.505953] dwmmc_starfive 16020000.sdio1: IDMAC supports 32-bit address mode.
[    3.505999] dwmmc_starfive 16020000.sdio1: Using internal DMA controller.
[    3.506011] dwmmc_starfive 16020000.sdio1: Version ID is 290a
[    3.506055] dwmmc_starfive 16020000.sdio1: DW MMC controller at irq 29,32 bit host data width,32 deep fifo
[    3.506187] mmc_host mmc1: card is polling.
[    3.512885] dwmmc_starfive 16010000.sdio0: Using internal DMA controller.
[    3.519522] jh7110-sec 16000000.crypto: will run requests pump with realtime priority
[    3.526563] dwmmc_starfive 16010000.sdio0: Version ID is 290a
[    3.526606] dwmmc_starfive 16010000.sdio0: DW MMC controller at irq 28,32 bit host data width,32 deep fifo
[    3.536755] jh7110-sec 16000000.crypto: Initialized
[    3.539265] mmc_host mmc0: card is non-removable.
[    3.549734] starfive-i2s 120b0000.i2stx_4ch0:  designware: play supported
[    3.599640] sf-mipi-dphy-tx 295e0000.mipi-dphy: sf_dphy_probe begin
[    3.605929] sf-mipi-dphy-tx 295e0000.mipi-dphy: ===> sf_dphy_probe enter, 715
[    3.613230] sf-mipi-dphy-tx 295e0000.mipi-dphy: control ECO
[    3.618813] sf-mipi-dphy-tx 295e0000.mipi-dphy: GET_AON_GP_REG
[    3.624661] sf-mipi-dphy-tx 295e0000.mipi-dphy: control ECO
[    3.630242] sf-mipi-dphy-tx 295e0000.mipi-dphy: supply mipi_1p8 not found, using dummy regulator
[    3.639817] sf-mipi-dphy-tx 295e0000.mipi-dphy: sf_dphy_probe end
[    3.646730] of_cfs_init
[    3.649207] of_cfs_init: OK
[    3.652346] starfive-pwmdac 100b0000.pwmdac: clk_apb0 = 49500000, clk_pwmdac_apb = 49500000, clk_pwmdac_core = 4068493
[    3.663331] cfg80211: Loading compiled-in X.509 certificates for regulatory database
[    3.720730] mmc_host mmc1: Bus speed (slot 0) = 198000000Hz (slot req 400000Hz, actual 399193HZ div = 248)
[    3.770733] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 400000Hz, actual 399193HZ div = 248)
[    3.783466] cfg80211: Loaded X.509 cert 'sforshee: 00b28ddf47aef9cea7'
[    3.795170] starfive soc:display-subsystem: bound 29400000.dc8200 (ops 0xffffffff80e73520)
[    3.804660] platform regulatory.0: Direct firmware load for regulatory.db failed with error -2
[    3.813391] cfg80211: failed to load regulatory.db
[    3.813866] innohdmi-starfive 29590000.hdmi: [drm:inno_hdmi_bind] registered Inno HDMI I2C bus driver success
[    3.828513] innohdmi-starfive 29590000.hdmi: HDMI&AUDIO register done.
[    3.835084] starfive soc:display-subsystem: bound 29590000.hdmi (ops 0xffffffff80e742d0)
[    3.843224] cdns-dsi 295d0000.mipi: dsi_sys_clk = 297000000
[    3.849125] seeed_panel 2-0045: Unknown Atmel firmware revision: 0x00
[    3.855621] cdns-dsi 295d0000.mipi: ====starfive_dsi_bind end
[    3.861381] starfive soc:display-subsystem: bound 295d0000.mipi (ops 0xffffffff80e74bf8)
[    3.869480] vs-simple-encoder soc:rgb-output: encoder_bind begin
[    3.875512] no panel, -19
[    3.878137] vs-simple-encoder soc:rgb-output: encoder_bind error
[    3.884154] starfive soc:display-subsystem: bound soc:rgb-output (ops 0xffffffff80e73f18)
[    3.892346] vs-simple-encoder soc:dsi-output: encoder_bind begin
[    3.898369] no panel, -517
[    3.901089] vs-simple-encoder soc:dsi-output: encoder_bind error
[    3.907098] starfive soc:display-subsystem: bound soc:dsi-output (ops 0xffffffff80e73f18)
[    3.915707] [drm] Initialized starfive 1.0.0 20191101 for soc:display-subsystem on minor 1
[    3.973293] mmc_host mmc1: Bus speed (slot 0) = 198000000Hz (slot req 50000000Hz, actual 49500000HZ div = 2)
[    3.983329] mmc1: new high speed SDXC card at address 59b4
[    3.989952] mmcblk1: mmc1:59b4 EC1S5 59.7 GiB
[    3.997978] random: fast init done
[    4.006417]  mmcblk1: p1 p2 p3
[    4.220791] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 300000Hz, actual 300000HZ div = 330)
[    4.660818] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 200000Hz, actual 200000HZ div = 495)
[    5.110840] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 100000Hz, actual 100000HZ div = 990)
[    6.010795] ALSA device list:
[    6.013815]   #0: Starfive-Multi-Sound-Card
[    6.022341] Freeing unused kernel image (initmem) memory: 2188K
[    6.028625] Run /init as init process
[    6.032400]   with arguments:
[    6.032417]     /init
[    6.032430]   with environment:
[    6.032446]     HOME=/
[    6.032459]     TERM=linux
[    6.032473]     stmmaceth=chain_mode:1
[    6.032492]     selinux=0
[    6.967245] EXT4-fs (mmcblk1p3): mounted filesystem with ordered data mode. Opts: (null). Quota mode: disabled.
[    7.670380] systemd[1]: System time before build time, advancing clock.
[    7.757931] systemd[1]: systemd 251.2-5 running in system mode (+PAM +AUDIT +SELINUX +APPARMOR +IMA +SMACK +SECCOMP +GCRYPT -GNUTLS +OPENSSL +ACL +BLKID +CURL +ELFUTILS +FIDO2 +IDN2 -IDN +IPTC +KMOD +LIBCRYPTSETUP +LIBFDISK +PCRE2 -PWQUALITY -P11KIT -QRENCODE +TPM2 +BZIP2 +LZ4 +XZ +ZLIB +ZSTD -BPF_FRAMEWORK -XKBCOMMON +UTMP +SYSVINIT default-hierarchy=unified)
[    7.789938] systemd[1]: Detected architecture riscv64.
[    7.797636] systemd[1]: Hostname set to <starfive>.
[    8.297379] systemd[1]: Queued start job for default target Graphical Interface.
[    8.306926] systemd[1]: Created slice Slice /system/getty.
[    8.313254] systemd[1]: Created slice Slice /system/modprobe.
[    8.320466] systemd[1]: Created slice Slice /system/serial-getty.
[    8.327723] systemd[1]: Created slice User and Session Slice.
[    8.334726] systemd[1]: Started Forward Password Requests to Wall Directory Watch.
[    8.343640] systemd[1]: Arbitrary Executable File Formats File System Automount Point was skipped because of a failed condition check (ConditionPathExists=/proc/sys/fs/binfmt_misc).
[    8.361195] systemd[1]: Reached target Local Integrity Protected Volumes.
[    8.369271] systemd[1]: Reached target Remote File Systems.
[    8.376146] systemd[1]: Reached target Slice Units.
[    8.382476] systemd[1]: Reached target Swaps.
[    8.388178] systemd[1]: Reached target Local Verity Protected Volumes.
[    8.397220] systemd[1]: Listening on Syslog Socket.
[    8.402482] systemd[1]: Listening on initctl Compatibility Named Pipe.
[    8.416383] systemd[1]: Journal Audit Socket was skipped because of a failed condition check (ConditionSecurity=audit).
[    8.428362] systemd[1]: Listening on Journal Socket (/dev/log).
[    8.435584] systemd[1]: Listening on Journal Socket.
[    8.441896] systemd[1]: Listening on udev Control Socket.
[    8.448543] systemd[1]: Listening on udev Kernel Socket.
[    8.457028] systemd[1]: Mounting Huge Pages File System...
[    8.465269] systemd[1]: Mounting POSIX Message Queue File System...
[    8.474278] systemd[1]: Mounting Kernel Debug File System...
[    8.481112] systemd[1]: Kernel Trace File System was skipped because of a failed condition check (ConditionPathExists=/sys/kernel/tracing).
[    8.495074] systemd[1]: Create List of Static Device Nodes was skipped because of a failed condition check (ConditionFileNotEmpty=/lib/modules/5.15.0-starfive/modules.devname).
[    8.514354] systemd[1]: Starting Load Kernel Module configfs...
[    8.524330] systemd[1]: Starting Load Kernel Module drm...
[    8.532808] systemd[1]: Starting Load Kernel Module fuse...
[    8.544628] systemd[1]: Starting Journal Service...
[    8.572068] systemd[1]: Starting Load Kernel Modules...
[    8.581548] systemd[1]: Starting Remount Root and Kernel File Systems...
[    8.589283] systemd[1]: Repartition Root Disk was skipped because all trigger condition checks failed.
[    8.603335] systemd[1]: Starting Coldplug All udev Devices...
[    8.615456] systemd[1]: Mounted Huge Pages File System.
[    8.622300] systemd[1]: Mounted POSIX Message Queue File System.
[    8.629645] systemd[1]: Mounted Kernel Debug File System.
[    8.636605] systemd[1]: modprobe@configfs.service: Deactivated successfully.
[    8.644429] systemd[1]: Finished Load Kernel Module configfs.
[    8.658110] systemd[1]: modprobe@drm.service: Deactivated successfully.
[    8.666423] systemd[1]: Finished Load Kernel Module drm.
[    8.673666] systemd[1]: modprobe@fuse.service: Deactivated successfully.
[    8.681198] systemd[1]: Finished Load Kernel Module fuse.
[    8.688046] systemd[1]: Started Journal Service.
[    8.749967] systemd-journald[255]: Received client request to flush runtime journal.
[    8.785014] systemd-journald[255]: File /var/log/journal/e593f8ed757a4b42a5589c96d5395702/system.journal corrupted or uncleanly shut down, renaming and replacing.
[    9.488750] systemd-journald[255]: Oldest entry in /var/log/journal/e593f8ed757a4b42a5589c96d5395702/system.journal is older than the configured file retention duration (1month), suggesting rotation.
[    9.507586] systemd-journald[255]: /var/log/journal/e593f8ed757a4b42a5589c96d5395702/system.journal: Journal header limits reached or header out-of-date, rotating.
[    9.632146] jpu: loading out-of-tree module taints kernel.
[    9.633996] vdec: loading out-of-tree module taints kernel.
[    9.639871] SUCCESS alloc_chrdev_region
[    9.650412] vdec 130a0000.vpu_dec: device init.
[    9.656067] SUCCESS alloc_chrdev_region
[    9.662465] cnm_jpu 13090000.jpu: init device.
[    9.901107] random: dbus-daemon: uninitialized urandom read (12 bytes read)
[    9.901828] random: avahi-daemon: uninitialized urandom read (4 bytes read)
[   10.790162] random: dbus-daemon: uninitialized urandom read (12 bytes read)
[   11.230196] starfive-eth-plat 16030000.ethernet eth0: PHY [stmmac-0:00] driver [YT8531 Gigabit Ethernet] (irq=POLL)
[   11.241274] starfive-eth-plat 16030000.ethernet eth0: Register MEM_TYPE_PAGE_POOL RxQ-0
[   11.259625] dwmac4: Master AXI performs fixed burst length
[   11.265199] starfive-eth-plat 16030000.ethernet eth0: No Safety Features support found
[   11.273197] starfive-eth-plat 16030000.ethernet eth0: IEEE 1588-2008 Advanced Timestamp supported
[   11.282499] starfive-eth-plat 16030000.ethernet eth0: configuring for phy/rgmii-id link mode
[   11.294290] starfive-eth-plat 16040000.ethernet eth1: PHY [stmmac-1:00] driver [YT8512B Ethernet] (irq=POLL)
[   11.304774] starfive-eth-plat 16040000.ethernet eth1: Register MEM_TYPE_PAGE_POOL RxQ-0
[   11.313098] dwmac4: Master AXI performs fixed burst length
[   11.317166] random: alsactl: uninitialized urandom read (4 bytes read)
[   11.318611] starfive-eth-plat 16040000.ethernet eth1: No Safety Features support found
[   11.318627] starfive-eth-plat 16040000.ethernet eth1: IEEE 1588-2008 Advanced Timestamp supported
[   11.342098] starfive-eth-plat 16040000.ethernet eth1: configuring for phy/rgmii-id link mode
[   11.354455] starfive-eth-plat 16040000.ethernet eth1: Link is Up - 100Mbps/Full - flow control off
[   11.390090] random: lightdm: uninitialized urandom read (16 bytes read)
[   11.466281] random: alsactl: uninitialized urandom read (4 bytes read)
[   11.690727] random: crng init done
[   11.751752] vs_gem_dumb_create size = 1000
[   11.755914] Allocated coherent memory, vaddr: 0xFFFFFFE0FECC0770, paddr: 0x104A22000
[   11.763726] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   12.215873] PVR_K:  400: RGX Firmware image 'rgx.fw.36.50.54.182' loaded
[   12.301315] PVR_K:  400: Shader binary image 'rgx.sh.36.50.54.182' loaded
[   12.310620] PVR_K:  400: X connected - (devID = 0)
[   12.584825] vs_gem_dumb_create size = 7e9000
[   12.589720] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFC4000, paddr: 0x80200000
[   12.597405] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   12.636677] vs_gem_dumb_create size = 4000
[   12.640929] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFC09C0, paddr: 0x80108000
[   12.648586] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   12.654353] vs_gem_dumb_create size = 4000
[   12.658532] Allocated coherent memory, vaddr: 0xFFFFFFE0FCFC0AA0, paddr: 0x8010C000
[   12.666205] ====> vs_gem_alloc_buf, 162.vs_obj->get_pages = 0
[   13.571720] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate rate 148500000 tmdsclk 148500000
[   13.581331] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->pixclock = 148500000
[   13.591104] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->tmdsclock = 148500000
[   13.600948] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->prediv = 1
[   13.609815] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->fbdiv = 99
[   13.618695] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->tmds_div_a = 1
[   13.627924] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->tmds_div_b = 1
[   13.637149] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->tmds_div_c = 1
[   13.646377] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->pclk_div_a = 1
[   13.655604] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->pclk_div_b = 2
[   13.664832] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->pclk_div_c = 2
[   13.674060] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->pclk_div_d = 2
[   13.683288] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->vco_div_5_en = 0
[   13.692697] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->pre_cfg->fracdiv = 0
[   13.701671] innohdmi-starfive 29590000.hdmi: *******************************************************
[   13.710813] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->tmdsclock = 148500000
[   13.720734] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->prediv = 1
[   13.729693] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->fbdiv = 20
[   13.738665] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->postdiv = 1
[   13.747726] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->post_div_en = 3
[   13.757134] innohdmi-starfive 29590000.hdmi: inno_hdmi_phy_clk_set_rate hdmi->post_cfg->version = 3
root@starfive:~#

なお、 https://debian.starfivetech.com/ から入手するDebian以外に、 StarFiveTech VisionFive2 SDK から入手できる sdcard.img というものもあります。

起動してみるとBuildrootのLinuxとして起動

Starting DHCP server: FAIL

Welcome to Buildroot
buildroot login: root
Password:
# uname -a
Linux buildroot 5.15.0 #1 SMP Sun Dec 25 20:59:22 CST 2022 riscv64 GNU/Linux
# apt
-sh: apt: not found
# df
Filesystem           1K-blocks      Used Available Use% Mounted on
devtmpfs          `    1669016         0   1669016   0% /dev
tmpfs          `  `    1993648      `  0  `1993648   0% /dev/shm
tmpfs          `  ``   1993648        64   1993584   0% /tmp
tmpfs          `  `   `1993648       196   1993452   0% /run
/dev/mmcblk1p4      ` ` 69346    245002    194648  56% /
#

まあ、パッケージ管理システムがないので、実用には向かない感じですかね

# dmesg
[    0.000000] Linux version 5.15.0 (jenkins@soft05) (riscv64-buildroot-linux-gnu-gcc.br_real (Buildroot VF2_v2.5.0) 10.3.0, GNU ld (GNU Binutils) 2.36.1) #1 SMP Sun Dec 25 20:59:22 CST 2022
[    0.000000] OF: fdt: Ignoring memory range 0x40000000 - 0x40200000
[    0.000000] Machine model: StarFive VisionFive V2
[    0.000000] earlycon: sbi0 at I/O port 0x0 (options '')
[    0.000000] printk: bootconsole [sbi0] enabled
[    0.000000] efi: UEFI not found.
[    0.000000] Reserved memory: created CMA memory pool at 0x0000000080000000, size 512 MiB
[    0.000000] OF: reserved mem: initialized node linux,cma, compatible id shared-dma-pool
[    0.000000] Zone ranges:
[    0.000000]   DMA32    [mem 0x0000000040200000-0x00000000ffffffff]
[    0.000000]   Normal   [mem 0x0000000100000000-0x000000013fffffff]
[    0.000000] Movable zone start for each node
[    0.000000] Early memory node ranges
[    0.000000]   node   0: [mem 0x0000000040200000-0x00000000c010ffff]
[    0.000000]   node   0: [mem 0x00000000c0110000-0x00000000c01fffff]
[    0.000000]   node   0: [mem 0x00000000c0200000-0x000000013fffffff]
[    0.000000] Initmem setup node 0 [mem 0x0000000040200000-0x000000013fffffff]
[    0.000000] SBI specification v0.3 detected
[    0.000000] SBI implementation ID=0x1 Version=0x10000
[    0.000000] SBI TIME extension detected
[    0.000000] SBI IPI extension detected
[    0.000000] SBI RFENCE extension detected
[    0.000000] SBI v0.2 HSM extension detected
[    0.000000] CPU with hartid=0 is not available
[    0.000000] CPU with hartid=0 is not available
[    0.000000] riscv: ISA extensions acdfim
[    0.000000] riscv: ELF capabilities acdfim
[    0.000000] percpu: Embedded 17 pages/cpu s31528 r8192 d29912 u69632
[    0.000000] pcpu-alloc: s31528 r8192 d29912 u69632 alloc=17*4096
[    0.000000] pcpu-alloc: [0] 0 [0] 1 [0] 2 [0] 3
[    0.000000] Built 1 zonelists, mobility grouping on.  Total pages: 1033735
[    0.000000] Kernel command line: earlyprintk console=ttyS0,115200 debug rootwait earlycon=sbi root=/dev/mmcblk1p4
[    0.000000] Unknown command line parameters: earlyprintk
[    0.000000] Dentry cache hash table entries: 524288 (order: 10, 4194304 bytes, linear)
[    0.000000] Inode-cache hash table entries: 262144 (order: 9, 2097152 bytes, linear)
[    0.000000] mem auto-init: stack:off, heap alloc:off, heap free:off
[    0.000000] software IO TLB: mapped [mem 0x00000000fbfff000-0x00000000fffff000] (64MB)
[    0.000000] Memory: 3338036K/4192256K available (9878K kernel code, 4982K rwdata, 4096K rodata, 2191K init, 401K bss, 329932K reserved, 524288K cma-reserved)
[    0.000000] SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=4, Nodes=1
[    0.000000] rcu: Hierarchical RCU implementation.
[    0.000000] rcu:     RCU restricting CPUs from NR_CPUS=8 to nr_cpu_ids=4.
[    0.000000] rcu:     RCU debug extended QS entry/exit.
[    0.000000]  Tracing variant of Tasks RCU enabled.
[    0.000000] rcu: RCU calculated value of scheduler-enlistment delay is 10 jiffies.
[    0.000000] rcu: Adjusting geometry for rcu_fanout_leaf=16, nr_cpu_ids=4
[    0.000000] NR_IRQS: 64, nr_irqs: 64, preallocated irqs: 0
[    0.000000] CPU with hartid=0 is not available
[    0.000000] riscv-intc: unable to find hart id for /cpus/cpu@0/interrupt-controller
[    0.000000] riscv-intc: 64 local interrupts mapped
[    0.000000] plic: plic@c000000: mapped 136 interrupts with 4 handlers for 9 contexts.
[    0.000000] random: get_random_bytes called from start_kernel+0x4d0/0x6e2 with crng_init=0
[    0.000000] riscv_timer_init_dt: Registering clocksource cpuid [0] hartid [3]
[    0.000000] clocksource: riscv_clocksource: mask: 0xffffffffffffffff max_cycles: 0x1d854df40, max_idle_ns: 881590404240 ns
[    0.000001] sched_clock: 64 bits at 4MHz, resolution 250ns, wraps every 2199023255500ns
[    0.008207] clocksource: timer@13050000.ch0: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.018416] clocksource: timer@13050000.ch1: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.028737] clocksource: timer@13050000.ch2: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.039044] clocksource: timer@13050000.ch3: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 79635851949 ns
[    0.049493] Console: colour dummy device 80x25
[    0.053893] Calibrating delay loop (skipped), value calculated using timer frequency.. 8.00 BogoMIPS (lpj=40000)
[    0.064089] pid_max: default: 32768 minimum: 301
[    0.068920] Mount-cache hash table entries: 8192 (order: 4, 65536 bytes, linear)
[    0.076318] Mountpoint-cache hash table entries: 8192 (order: 4, 65536 bytes, linear)
[    0.085379] ASID allocator disabled
[    0.088882] rcu: Hierarchical SRCU implementation.
[    0.093794] EFI services will not be available.
[    0.098582] smp: Bringing up secondary CPUs ...
[    0.104458] smp: Brought up 1 node, 4 CPUs
[    0.109521] devtmpfs: initialized
[    0.118784] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604462750000 ns
[    0.128559] futex hash table entries: 1024 (order: 4, 65536 bytes, linear)
[    0.148220] pinctrl core: initialized pinctrl subsystem
[    0.154189] NET: Registered PF_NETLINK/PF_ROUTE protocol family
[    0.160600] cpuidle: using governor menu
[    0.181977] platform soc:dsi-output: Fixing up cyclic dependency with 29400000.dc8200
[    0.190170] platform 295d0000.mipi: Fixing up cyclic dependency with soc:dsi-output
[    0.198067] platform 29590000.hdmi: Fixing up cyclic dependency with 29400000.dc8200
[    0.215374] HugeTLB registered 1.00 GiB page size, pre-allocated 0 pages
[    0.222021] HugeTLB registered 2.00 MiB page size, pre-allocated 0 pages
[    0.231460] vgaarb: loaded
[    0.234304] SCSI subsystem initialized
[    0.238091] libata version 3.00 loaded.
[    0.242011] usbcore: registered new interface driver usbfs
[    0.247462] usbcore: registered new interface driver hub
[    0.252810] usbcore: registered new device driver usb
[    0.258230] mc: Linux media interface: v0.10
[    0.262431] videodev: Linux video capture interface: v2.00
[    0.268126] Advanced Linux Sound Architecture Driver Initialized.
[    0.274452] Bluetooth: Core ver 2.22
[    0.277965] NET: Registered PF_BLUETOOTH protocol family
[    0.283315] Bluetooth: HCI device and connection manager initialized
[    0.289740] Bluetooth: HCI socket layer initialized
[    0.294672] Bluetooth: L2CAP socket layer initialized
[    0.299800] Bluetooth: SCO socket layer initialized
[    0.304985] clocksource: Switched to clocksource riscv_clocksource
[    0.316941] NET: Registered PF_INET protocol family
[    0.322381] IP idents hash table entries: 65536 (order: 7, 524288 bytes, linear)
[    0.332924] tcp_listen_portaddr_hash hash table entries: 2048 (order: 4, 81920 bytes, linear)
[    0.341481] TCP established hash table entries: 32768 (order: 6, 262144 bytes, linear)
[    0.349724] TCP bind hash table entries: 32768 (order: 8, 1048576 bytes, linear)
[    0.358126] TCP: Hash tables configured (established 32768 bind 32768)
[    0.364831] UDP hash table entries: 2048 (order: 5, 196608 bytes, linear)
[    0.371792] UDP-Lite hash table entries: 2048 (order: 5, 196608 bytes, linear)
[    0.379358] NET: Registered PF_UNIX/PF_LOCAL protocol family
[    0.385460] RPC: Registered named UNIX socket transport module.
[    0.391302] RPC: Registered udp transport module.
[    0.396086] RPC: Registered tcp transport module.
[    0.400834] RPC: Registered tcp NFSv4.1 backchannel transport module.
[    0.407928] PCI: CLS 0 bytes, default 64
[    0.412310] Initialise system trusted keyrings
[    0.416845] workingset: timestamp_bits=62 max_order=20 bucket_order=0
[    0.417043] Unpacking initramfs...
[    0.428050] NFS: Registering the id_resolver key type
[    0.433040] Key type id_resolver registered
[    0.437306] Key type id_legacy registered
[    0.441427] nfs4filelayout_init: NFSv4 File Layout Driver Registering...
[    0.448133] nfs4flexfilelayout_init: NFSv4 Flexfile Layout Driver Registering...
[    0.455616] ntfs: driver 2.1.32 [Flags: R/W].
[    0.460206] jffs2: version 2.2. (NAND) \xc2\xa9 2001-2006 Red Hat, Inc.
[    0.466609] fuse: init (API version 7.34)
[    0.502722] NET: Registered PF_ALG protocol family
[    0.507481] Key type asymmetric registered
[    0.511608] Asymmetric key parser 'x509' registered
[    0.516645] Block layer SCSI generic (bsg) driver version 0.4 loaded (major 249)
[    0.524002] io scheduler mq-deadline registered
[    0.528621] io scheduler kyber registered
[    0.533253] start plist test
[    0.538623] end plist test
[    0.621657] clk-starfive-jh7110 13020000.clock-controller: starfive JH7110 clkgen init successfully.
[    0.631893] L2CACHE: DataError @ 0x00000000.080400F8
[    0.636868] L2CACHE: DataFail @ 0x00000000.0804005B
[    0.641801] L2CACHE: No. of Banks in the cache: 8
[    0.646512] L2CACHE: No. of ways per bank: 16
[    0.650916] L2CACHE: Sets per bank: 256
[    0.654816] L2CACHE: Bytes per cache block: 64
[    0.659342] L2CACHE: Index of the largest way enabled: 15
[    0.665131] jh7110-pmu 17030000.power-controller: registered 8 power domains
[    0.733104] Serial: 8250/16550 driver, 6 ports, IRQ sharing disabled
[    0.742249] @@#########################@@
[    0.784445] @@ dev ptr:ffffffe0bfee0000/1500/1
[    0.789085] PVR_K:  1: Read BVNC 36.50.54.182 from HW device registers
[    0.795622] PVR_K:  1: RGX Device registered BVNC 36.50.54.182 with 1 core in the system
[    0.804932] [drm] Initialized pvr 1.17.6210866 20170530 for 18000000.gpu on minor 0
[    0.821652] loop: module loaded
[    0.827242] spi-nor spi0.0: gd25lq128d (16384 Kbytes)
[    6.163101] Initramfs unpacking failed: invalid magic at start of compressed archive
[    6.335156] Freeing initrd memory: 122788K
[    6.350721] 3 fixed-partitions partitions found on MTD device 13010000.spi.0
[    6.357746] Creating 3 MTD partitions on "13010000.spi.0":
[    6.363263] 0x000000000000-0x000000020000 : "spl"
[    6.369876] 0x000000100000-0x000000400000 : "uboot"
[    6.376294] 0x000000f00000-0x000001000000 : "data"
[    6.383678] libphy: Fixed MDIO Bus: probed
[    6.389233] CAN device driver interface
[    6.393580] starfive-eth-plat 16030000.ethernet: force_sf_dma_mode is ignored if force_thresh_dma_mode is set.
[    6.403898] starfive-eth-plat 16030000.ethernet: User ID: 0x41, Synopsys ID: 0x52
[    6.411332] starfive-eth-plat 16030000.ethernet:     DWMAC4/5
[    6.416867] starfive-eth-plat 16030000.ethernet: DMA HW capability register supported
[    6.424738] starfive-eth-plat 16030000.ethernet: RX Checksum Offload Engine supported
[    6.432635] starfive-eth-plat 16030000.ethernet: Wake-Up On Lan supported
[    6.439481] starfive-eth-plat 16030000.ethernet: TSO supported
[    6.445375] starfive-eth-plat 16030000.ethernet: Enable RX Mitigation via HW Watchdog Timer
[    6.453773] starfive-eth-plat 16030000.ethernet: Enabled Flow TC (entries=1)
[    6.460890] starfive-eth-plat 16030000.ethernet: TSO feature enabled
[    6.467302] starfive-eth-plat 16030000.ethernet: Using 40 bits DMA width
[    6.716361] libphy: stmmac: probed
[    6.719701] YT8531 Gigabit Ethernet stmmac-0:00: attached PHY driver (mii_bus:phy_addr=stmmac-0:00, irq=POLL)
[    6.729693] YT8531 Gigabit Ethernet stmmac-0:01: attached PHY driver (mii_bus:phy_addr=stmmac-0:01, irq=POLL)
[    6.740838] starfive-eth-plat 16040000.ethernet: force_sf_dma_mode is ignored if force_thresh_dma_mode is set.
[    6.751143] starfive-eth-plat 16040000.ethernet: User ID: 0x41, Synopsys ID: 0x52
[    6.758574] starfive-eth-plat 16040000.ethernet:     DWMAC4/5
[    6.764097] starfive-eth-plat 16040000.ethernet: DMA HW capability register supported
[    6.771996] starfive-eth-plat 16040000.ethernet: RX Checksum Offload Engine supported
[    6.779881] starfive-eth-plat 16040000.ethernet: Wake-Up On Lan supported
[    6.786728] starfive-eth-plat 16040000.ethernet: TSO supported
[    6.792608] starfive-eth-plat 16040000.ethernet: Enable RX Mitigation via HW Watchdog Timer
[    6.801034] starfive-eth-plat 16040000.ethernet: Enabled Flow TC (entries=1)
[    6.808137] starfive-eth-plat 16040000.ethernet: TSO feature enabled
[    6.814536] starfive-eth-plat 16040000.ethernet: Using 40 bits DMA width
[    7.062390] libphy: stmmac: probed
[    7.065758] YT8512B Ethernet stmmac-1:00: attached PHY driver (mii_bus:phy_addr=stmmac-1:00, irq=POLL)
[    7.075101] YT8512B Ethernet stmmac-1:03: attached PHY driver (mii_bus:phy_addr=stmmac-1:03, irq=POLL)
[    7.085971] Intel(R) Wireless WiFi driver for Linux
[    7.092653] cdns3-starfive 10210000.usbdrd: usb mode 2 2.0 probe success
[    7.100068] usbcore: registered new interface driver uas
[    7.105381] usbcore: registered new interface driver usb-storage
[    7.125324] starfive-rtc 17040000.rtc: registered as rtc0
[    7.130661] starfive-rtc 17040000.rtc: setting system clock to 2001-01-01T00:00:00 UTC (978307200)
[    7.139816] i2c_dev: i2c /dev entries driver
[    7.144258] usbcore: registered new interface driver uvcvideo
[    7.151107] starfive-wdt 13070000.wdog: Heartbeat: timeout=15, count/2=180000000 (0aba9500)
[    7.159926] Bluetooth: HCI UART driver ver 2.3
[    7.164299] Bluetooth: HCI UART protocol H4 registered
[    7.169730] starfive-cpufreq soc:starfive,jh7110-cpufreq: Failed to get regulator for cpu!
[    7.177948] starfive-cpufreq soc:starfive,jh7110-cpufreq: Failed to init starfive cpu dvfs info
[    7.187226] sdhci: Secure Digital Host Controller Interface driver
[    7.193340] sdhci: Copyright(c) Pierre Ossman
[    7.197808] Synopsys Designware Multimedia Card Interface Driver
[    7.204133] sdhci-pltfm: SDHCI platform and OF driver helper
[    7.210534] jh7110-sec 16000000.crypto: Unable to request sec_m dma channel in DMA channel
[    7.218766] jh7110-sec 16000000.crypto: Cannot initial dma chan
[    7.225021] usbcore: registered new interface driver usbhid
[    7.230525] usbhid: USB HID core driver
[    7.234668] usbcore: registered new interface driver snd-usb-audio
[    7.244078] NET: Registered PF_PACKET protocol family
[    7.249105] can: controller area network core
[    7.253577] NET: Registered PF_CAN protocol family
[    7.258352] can: raw protocol
[    7.261374] can: broadcast manager protocol
[    7.265654] can: netlink gateway - max_hops=1
[    7.270319] Bluetooth: RFCOMM TTY layer initialized
[    7.275156] Bluetooth: RFCOMM socket layer initialized
[    7.280348] Bluetooth: RFCOMM ver 1.11
[    7.284174] Bluetooth: BNEP (Ethernet Emulation) ver 1.3
[    7.289527] Bluetooth: BNEP filters: protocol multicast
[    7.294807] Bluetooth: BNEP socket layer initialized
[    7.300037] 9pnet: Installing 9P2000 support
[    7.304298] Key type dns_resolver registered
[    7.309315] Loading compiled-in X.509 certificates
[    7.349770] starfive_jh7110-pinctrl 13040000.gpio: SiFive GPIO chip registered 64 GPIOs
[    7.358542] starfive_jh7110-pinctrl 17020000.gpio: SiFive GPIO chip registered 4 GPIOs
[    7.366630] pl08xdmac 16008000.sec_dma: initialized 8 virtual memcpy channels
[    7.373710] pl08xdmac 16008000.sec_dma: initialized 16 virtual slave channels
[    7.382563] debugfs: Directory '16008000.sec_dma' with parent 'dmaengine' already present!
[    7.390808] pl08xdmac 16008000.sec_dma: DMA: PL080 rev0 at 0x16008000 irq 23
[    7.398152] ssp-pl022 10060000.spi: ARM PL022 driver for StarFive SoC platform, device ID: 0x00041022
[    7.407335] ssp-pl022 10060000.spi: mapped registers from 0x0000000010060000 to (____ptrval____)
[    7.416616] ssp-pl022 10060000.spi: Requested frequency: 10000000 Hz is unsupported,select by default 8250000 Hz
[    7.427123] ssp-pl022 10060000.spi: will use autosuspend for runtime pm, delay 100ms
[    7.436132] i2c 2-0045: Fixing up cyclic dependency with 295d0000.mipi
[    7.442852] seeed_panel 2-0045: Unknown Atmel firmware revision: 0x00
[    7.449451] i2c 2-0019: Fixing up cyclic dependency with 295d0000.mipi
[    7.457354] at24 5-0050: supply vcc not found, using dummy regulator
[    7.464420] at24 5-0050: 512 byte 24c04 EEPROM, writable, 16 bytes/write
[    7.472982] axp15060-regulator 5-0036: Register mipi_0p9 done! vol range:900 ~ 900 mV
[    7.482264] axp15060-regulator 5-0036: Register hdmi_1p8 done! vol range:1800 ~ 1800 mV
[    7.491702] axp15060-regulator 5-0036: Register hdmi_0p9 done! vol range:900 ~ 900 mV
[    7.500980] axp15060-regulator 5-0036: Register cpu_vdd done! vol range:500 ~ 1540 mV
[    7.509530] i2c 6-0010: Fixing up cyclic dependency with 19800000.vin_sysctl
[    7.516925] imx219 6-0010: supply VANA not found, using dummy regulator
[    7.523594] imx219 6-0010: supply VDIG not found, using dummy regulator
[    7.530237] imx219 6-0010: supply VDDL not found, using dummy regulator
[    7.544306] imx219 6-0010: failed to read chip id 219
[    7.549516] imx219: probe of 6-0010 failed with error -5
[    7.557305] pcie_plda 2b000000.pcie: host bridge /soc/pcie@2B000000 ranges:
[    7.564244] pcie_plda 2b000000.pcie:      MEM 0x0030000000..0x0037ffffff -> 0x0030000000
[    7.572409] pcie_plda 2b000000.pcie:      MEM 0x0900000000..0x093fffffff -> 0x0900000000
[    7.580567] ATR entry: 0x0940000000 -> 0x0000000000 [0x0010000000] (param: 0x000001)
[    7.588333] ATR entry: 0x0030000000 -> 0x0030000000 [0x0008000000] (param: 0x000000)
[    7.596119] ATR entry: 0x0900000000 -> 0x0900000000 [0x0040000000] (param: 0x000000)
[    7.945086] pcie_plda 2b000000.pcie: Port link up.
[    7.949963] pcie_plda 2b000000.pcie: PCI host bridge to bus 0000:00
[    7.956182] pci_bus 0000:00: root bus resource [bus 00-ff]
[    7.961705] pci_bus 0000:00: root bus resource [mem 0x30000000-0x37ffffff]
[    7.968653] pci_bus 0000:00: root bus resource [mem 0x900000000-0x93fffffff pref]
[    7.976220] pci 0000:00:00.0: [1556:1111] type 01 class 0x060400
[    7.982255] pci 0000:00:00.0: reg 0x10: [mem 0x00000000-0xffffffff 64bit pref]
[    7.989597] pci 0000:00:00.0: supports D1 D2
[    7.993858] pci 0000:00:00.0: PME# supported from D0 D1 D2 D3hot D3cold
[    8.004020] pci 0000:00:00.0: bridge configuration invalid ([bus 00-00]), reconfiguring
[    8.012105] pci 0000:01:00.0: [1106:3483] type 00 class 0x0c0330
[    8.018068] pci 0000:01:00.0: reg 0x10: [mem 0x00000000-0x00000fff 64bit]
[    8.024966] pci 0000:01:00.0: PME# supported from D0 D3cold
[    8.033819] pci_bus 0000:01: busn_res: [bus 01-ff] end is updated to 01
[    8.040414] pci 0000:00:00.0: BAR 0: no space for [mem size 0x100000000 64bit pref]
[    8.048093] pci 0000:00:00.0: BAR 0: failed to assign [mem size 0x100000000 64bit pref]
[    8.056154] pci 0000:00:00.0: BAR 8: assigned [mem 0x30000000-0x300fffff]
[    8.062990] pci 0000:01:00.0: BAR 0: assigned [mem 0x30000000-0x30000fff 64bit]
[    8.070377] pci 0000:00:00.0: PCI bridge to [bus 01]
[    8.075394] pci 0000:00:00.0:   bridge window [mem 0x30000000-0x300fffff]
[    8.082330] pci 0000:00:00.0: enabling device (0000 -> 0002)
[    8.087968] pci 0000:01:00.0: enabling device (0000 -> 0002)
[    8.093697] pci 0000:01:00.0: quirk_usb_early_handoff+0x0/0x9d4 took 11109 usecs
[    8.101345] xhci_hcd 0000:01:00.0: xHCI Host Controller
[    8.106537] xhci_hcd 0000:01:00.0: new USB bus registered, assigned bus number 1
[    8.114362] xhci_hcd 0000:01:00.0: hcc params 0x002841eb hci version 0x100 quirks 0x0000040000000890
[    8.123534] pcie_plda 2b000000.pcie: msi#0 address_hi 0x0 address_lo 0x190
[    8.130747] xhci_hcd 0000:01:00.0: xHCI Host Controller
[    8.135929] xhci_hcd 0000:01:00.0: new USB bus registered, assigned bus number 2
[    8.143361] xhci_hcd 0000:01:00.0: Host supports USB 3.0 SuperSpeed
[    8.150455] hub 1-0:1.0: USB hub found
[    8.154164] hub 1-0:1.0: 1 port detected
[    8.159175] hub 2-0:1.0: USB hub found
[    8.162884] hub 2-0:1.0: 4 ports detected
[    8.169690] pcie_plda 2c000000.pcie: host bridge /soc/pcie@2C000000 ranges:
[    8.176646] pcie_plda 2c000000.pcie:      MEM 0x0038000000..0x003fffffff -> 0x0038000000
[    8.184755] pcie_plda 2c000000.pcie:      MEM 0x0980000000..0x09bfffffff -> 0x0980000000
[    8.192956] ATR entry: 0x09c0000000 -> 0x0000000000 [0x0010000000] (param: 0x000001)
[    8.200713] ATR entry: 0x0038000000 -> 0x0038000000 [0x0008000000] (param: 0x000000)
[    8.208504] ATR entry: 0x0980000000 -> 0x0980000000 [0x0040000000] (param: 0x000000)
[    8.375033] usb usb2-port2: over-current condition
[    8.475048] usb 1-1: new high-speed USB device number 2 using xhci_hcd
[    8.535067] usb usb2-port4: over-current condition
[    8.645256] pcie_plda 2c000000.pcie: Port link down, exit.
[    8.664394] clk-starfive-jh7110-vout 295c0000.clock-controller: starfive JH7110 clk_vout init successfully.
[    8.666191] hub 1-1:1.0: USB hub found
[    8.683633] hub 1-1:1.0: 4 ports detected
[    8.685694] clk-starfive-jh7110-isp 19810000.clock-controller: starfive JH7110 clk_isp init successfully.
[    8.697845] dw_axi_dmac_platform 16050000.dma-controller: DesignWare AXI DMA Controller, 4 channels
[    8.707898] printk: console [ttyS0] disabled
[    8.732341] 10000000.serial: ttyS0 at MMIO 0x10000000 (irq = 17, base_baud = 1500000) is a 16550A
[    8.741251] printk: console [ttyS0] enabled
[    8.749550] printk: bootconsole [sbi0] disabled
[    8.759171] jh7110-vin 19800000.vin_sysctl: stfcamss probe enter!
[    8.767285] jh7110-vin 19800000.vin_sysctl: stfcamss probe success!
[    8.776062] dwmmc_starfive 16010000.sdio0: IDMAC supports 32-bit address mode.
[    8.776520] dwmmc_starfive 16020000.sdio1: IDMAC supports 32-bit address mode.
[    8.783348] dwmmc_starfive 16010000.sdio0: Using internal DMA controller.
[    8.790619] dwmmc_starfive 16020000.sdio1: Using internal DMA controller.
[    8.797391] dwmmc_starfive 16010000.sdio0: Version ID is 290a
[    8.804178] dwmmc_starfive 16020000.sdio1: Version ID is 290a
[    8.809968] dwmmc_starfive 16010000.sdio0: DW MMC controller at irq 29,32 bit host data width,32 deep fifo
[    8.810081] jh7110-sec 16000000.crypto: will run requests pump with realtime priority
[    8.813252] jh7110-sec 16000000.crypto: Initialized
[    8.814330] starfive-i2s 120b0000.i2stx_4ch0:  designware: play supported
[    8.814340] starfive-i2s 120b0000.i2stx_4ch0: designware: i2s master mode supported
[    8.814517] sf-mipi-dphy-tx 295e0000.mipi-dphy: sf_dphy_probe begin
[    8.814530] sf-mipi-dphy-tx 295e0000.mipi-dphy: ===> sf_dphy_probe enter, 445
[    8.814656] sf-mipi-dphy-tx 295e0000.mipi-dphy: control ECO
[    8.814676] sf-mipi-dphy-tx 295e0000.mipi-dphy: supply mipi_1p8 not found, using dummy regulator
[    8.814961] sf-mipi-dphy-tx 295e0000.mipi-dphy: sf_dphy_probe end
[    8.815177] cdns-dsi 295d0000.mipi: dsi_sys_clk = 297000000
[    8.815414] cdns-dsi 295d0000.mipi: starfive dsi bind end
[    8.815749] dwmmc_starfive 16020000.sdio1: DW MMC controller at irq 30,32 bit host data width,32 deep fifo
[    8.817635] of_cfs_init
[    8.817676] of_cfs_init: OK
[    8.818197] starfive-pwmdac 100b0000.pwmdac: clk_apb0 = 49500000, clk_pwmdac_apb = 49500000, clk_pwmdac_core = 4068493
[    8.818696] cfg80211: Loading compiled-in X.509 certificates for regulatory database
[    8.825533] mmc_host mmc0: card is non-removable.
[    8.833373] mmc_host mmc1: card is polling.
[    8.929459] cfg80211: Loaded X.509 cert 'sforshee: 00b28ddf47aef9cea7'
[    8.948766] starfive soc:display-subsystem: bound 29400000.dc8200 (ops 0xffffffff80e75b38)
[    8.957085] innohdmi-starfive 29590000.hdmi: inno hdmi bind begin
[    8.963977] platform regulatory.0: Direct firmware load for regulatory.db failed with error -2
[    8.972619] cfg80211: failed to load regulatory.db
[    8.972931] innohdmi-starfive 29590000.hdmi: [drm:inno_hdmi_bind] registered Inno HDMI I2C bus driver success
[    8.987563] innohdmi-starfive 29590000.hdmi: HDMI&AUDIO register done.
[    8.994127] innohdmi-starfive 29590000.hdmi: inno hdmi bind end
[    9.000087] starfive soc:display-subsystem: bound 29590000.hdmi (ops 0xffffffff80e768e8)
[    9.008196] vs-simple-encoder soc:dsi-output: encoder_bind begin
[    9.014217] no panel, -517
[    9.016930] vs-simple-encoder soc:dsi-output: encoder_bind error
[    9.022932] starfive soc:display-subsystem: bound soc:dsi-output (ops 0xffffffff80e76530)
[    9.031555] [drm] Initialized starfive 1.0.0 20191101 for soc:display-subsystem on minor 1
[    9.055005] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 400000Hz, actual 399193HZ div = 248)
[    9.145059] mmc_host mmc1: Bus speed (slot 0) = 198000000Hz (slot req 400000Hz, actual 399193HZ div = 248)
[    9.290157] random: fast init done
[    9.397446] mmc_host mmc1: Bus speed (slot 0) = 198000000Hz (slot req 50000000Hz, actual 49500000HZ div = 2)
[    9.408322] mmc1: new high speed SDXC card at address 59b4
[    9.415198] mmcblk1: mmc1:59b4 ED2S5 119 GiB
[    9.428259]  mmcblk1: p1 p2 p3 p4
[    9.505093] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 300000Hz, actual 300000HZ div = 330)
[    9.945051] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 200000Hz, actual 200000HZ div = 495)
[   10.395102] mmc_host mmc0: Bus speed (slot 0) = 198000000Hz (slot req 100000Hz, actual 100000HZ div = 990)
[   11.055070] ALSA device list:
[   11.058064]   #0: Starfive-PWMDAC-Sound-Card
[   11.062364]   #1: Starfive-HDMI-Sound-Card
[   11.071575] Freeing unused kernel image (initmem) memory: 2188K
[   11.077824] Run /init as init process
[   11.081513]   with arguments:
[   11.084498]     /init
[   11.086825]     earlyprintk
[   11.089640]   with environment:
[   11.092804]     HOME=/
[   11.095211]     TERM=linux
[   11.218169] EXT4-fs (mmcblk1p4): mounted filesystem with ordered data mode. Opts: (null). Quota mode: disabled.
[   11.784545] EXT4-fs (mmcblk1p4): re-mounted. Opts: (null). Quota mode: disabled.
[   12.264121] udevd[221]: starting version 3.2.10
[   12.280697] random: udevd: uninitialized urandom read (16 bytes read)
[   12.288433] random: udevd: uninitialized urandom read (16 bytes read)
[   12.294947] random: udevd: uninitialized urandom read (16 bytes read)
[   12.355311] udevd[222]: starting eudev-3.2.10
[   12.470759] jpu: loading out-of-tree module taints kernel.
[   12.479700] vdec 130a0000.vpu_dec: device init.
[   12.482697] cnm_jpu 13090000.jpu: init device.
[   12.484250] SUCCESS alloc_chrdev_region
[   12.484633] SUCCESS alloc_chrdev_region
[   13.172744] starfive-eth-plat 16030000.ethernet eth0: PHY [stmmac-0:00] driver [YT8531 Gigabit Ethernet] (irq=POLL)
[   13.184615] starfive-eth-plat 16030000.ethernet eth0: Register MEM_TYPE_PAGE_POOL RxQ-0
[   13.203187] dwmac4: Master AXI performs fixed burst length
[   13.208732] starfive-eth-plat 16030000.ethernet eth0: No Safety Features support found
[   13.218053] starfive-eth-plat 16030000.ethernet eth0: IEEE 1588-2008 Advanced Timestamp supported
[   13.227963] starfive-eth-plat 16030000.ethernet eth0: configuring for phy/rgmii-id link mode
[   13.238746] starfive-eth-plat 16040000.ethernet eth1: PHY [stmmac-1:00] driver [YT8512B Ethernet] (irq=POLL)
[   13.248829] starfive-eth-plat 16040000.ethernet eth1: Register MEM_TYPE_PAGE_POOL RxQ-0
[   13.257127] dwmac4: Master AXI performs fixed burst length
[   13.262625] starfive-eth-plat 16040000.ethernet eth1: No Safety Features support found
[   13.270565] starfive-eth-plat 16040000.ethernet eth1: IEEE 1588-2008 Advanced Timestamp supported
[   13.281166] starfive-eth-plat 16040000.ethernet eth1: configuring for phy/rgmii-id link mode
[   13.292204] starfive-eth-plat 16040000.ethernet eth1: Link is Up - 100Mbps/Full - flow control off
[   38.975439] mipi_0p9: disabling
[  163.455196] random: crng init done
[  163.458654] random: 7 urandom warning(s) missed due to ratelimiting
#

Orange Pi 5純正のUbuntuのGPU表示を高速化できるのか?


ゆきまくらさんの「OrangePi5の公式xfceイメージにビデオドライバーをあてる」にGPUドライバを適用する話が書かれていた。

ただ上記だと詳細がわからないので、いろいろ調べながら試してみた。

現状調査

まず、同じRK3588S使っているKhadas Edge 2 Proあたりの情報みればなんかあるかな?と、cnxsoftwareにある「Khadas Edge2 Pro review – A Rockchip RK3588S SBC tested with Ubuntu 22.04」を読んでみる

「inxi -Fc0」というコマンドを実行するとハードウェア構成が出る、と

orangepi@orangepi5:~$ inxi -Fc0
System:
  Host: orangepi5 Kernel: 5.10.110-rockchip-rk3588 aarch64 bits: 64
    Desktop: Xfce 4.16.0 Distro: Ubuntu 22.04.1 LTS (Jammy Jellyfish)
Machine:
  Type: ARM System: Orange Pi 5 details: N/A
CPU:
  Info: 3x 4-core model: N/A variant-1: cortex-a76 variant-2: cortex-a55
    bits: 64 type: MCP AMP cache: L2: 3x 512 KiB (1.5 MiB)
  Speed (MHz): avg: 408 min/max: 408/1800:2400 cores: 1: 408 2: 408 3: 408
    4: 408 5: 408 6: 408 7: 408 8: 408
Graphics:
  Device-1: display-subsystem driver: rockchip_drm v: N/A
  Device-2: mali-bifrost driver: mali v: N/A
  Device-3: rk3588-dw-hdmi driver: dwhdmi_rockchip v: N/A
  Display: server: X.Org v: 1.21.1.3 driver: X: loaded: modesetting
    gpu: rockchip_drm,mali,dwhdmi_rockchip resolution: 1920x1080~60Hz
  OpenGL: renderer: llvmpipe (LLVM 13.0.1 128 bits) v: 4.5 Mesa 22.0.5
Audio:
  Device-1: hdmi driver: rk_hdmi_sound
  Device-2: rk3588-dw-hdmi driver: dwhdmi_rockchip
  Device-3: hdmi driver: rk_hdmi_sound
  Sound Server-1: ALSA v: k5.10.110-rockchip-rk3588 running: yes
  Sound Server-2: PulseAudio v: 15.99.1 running: yes
Network:
  Device-1: rk3588-gmac driver: rk_gmac_dwmac
  IF: eth0 state: up speed: 1000 Mbps duplex: full mac: 66:bd:6f:11:95:d7
Drives:
  Local Storage: total: 29.9 GiB used: 11.49 GiB (38.4%)
  ID-1: /dev/mmcblk1 model: 5cMJR size: 29.9 GiB
Partition:
  ID-1: / size: 29.14 GiB used: 11.4 GiB (39.1%) fs: ext4 dev: /dev/mmcblk1p2
  ID-2: /boot size: 255.7 MiB used: 94.2 MiB (36.8%) fs: vfat
    dev: /dev/mmcblk1p1
  ID-3: /var/log size: 187.3 MiB used: 2.4 MiB (1.3%) fs: ext4
    dev: /dev/zram1
Swap:
  ID-1: swap-1 type: zram size: 3.75 GiB used: 0 KiB (0.0%) dev: /dev/zram0
Sensors:
  System Temperatures: cpu: 40.7 C mobo: N/A
  Fan Speeds (RPM): N/A
Info:
  Processes: 246 Uptime: 7m Memory: 7.51 GiB used: 796.8 MiB (10.4%)
  Shell: Bash inxi: 3.3.13
orangepi@orangepi5:~$

「glxinfo -B」で現在使用しているGPU出力に関する設定が分かるらしく「OpenGL renderer string: llvmpipe (LLVM 13.0.1, 128 bits)」を使ってる

orangepi@orangepi5:~$ glxinfo -B
name of display: :0
libGL error: failed to create dri screen
libGL error: failed to load driver: rockchip
libGL error: failed to create dri screen
libGL error: failed to load driver: rockchip
display: :0  screen: 0
direct rendering: Yes
Extended renderer info (GLX_MESA_query_renderer):
    Vendor: Mesa/X.org (0xffffffff)
    Device: llvmpipe (LLVM 13.0.1, 128 bits) (0xffffffff)
    Version: 22.0.5
    Accelerated: no
    Video memory: 7689MB
    Unified memory: no
    Preferred profile: core (0x1)
    Max core profile version: 4.5
    Max compat profile version: 4.5
    Max GLES1 profile version: 1.1
    Max GLES[23] profile version: 3.2
OpenGL vendor string: Mesa/X.org
OpenGL renderer string: llvmpipe (LLVM 13.0.1, 128 bits)
OpenGL core profile version string: 4.5 (Core Profile) Mesa 22.0.5
OpenGL core profile shading language version string: 4.50
OpenGL core profile context flags: (none)
OpenGL core profile profile mask: core profile

OpenGL version string: 4.5 (Compatibility Profile) Mesa 22.0.5
OpenGL shading language version string: 4.50
OpenGL context flags: (none)
OpenGL profile mask: compatibility profile

OpenGL ES profile version string: OpenGL ES 3.2 Mesa 22.0.5
OpenGL ES profile shading language version string: OpenGL ES GLSL ES 3.20

orangepi@orangepi5:~$

「eglinfo」でも情報がある

orangepi@orangepi5:~$ eglinfo
EGL client extensions string:
    EGL_EXT_client_extensions EGL_EXT_platform_base
    EGL_KHR_client_get_all_proc_addresses EGL_KHR_platform_x11
    EGL_EXT_platform_x11 EGL_KHR_platform_gbm

GBM platform:
arm_release_ver of this libmali is 'g6p0-01eac0', rk_so_ver is '5'.
eglinfo: eglInitialize failed

X11 platform:
EGL API version: 1.4
EGL vendor string: ARM
EGL version string: 1.4 Valhall-"g6p0-01eac0"
EGL client APIs: OpenGL_ES
EGL extensions string:
    EGL_NV_context_priority_realtime EGL_KHR_image_pixmap
    EGL_KHR_partial_update EGL_EXT_image_dma_buf_import
    EGL_KHR_config_attribs EGL_KHR_image EGL_KHR_image_base
    EGL_KHR_fence_sync EGL_KHR_wait_sync EGL_KHR_gl_colorspace
    EGL_KHR_get_all_proc_addresses EGL_IMG_context_priority
    EGL_KHR_no_config_context EGL_EXT_image_dma_buf_import
    EGL_EXT_image_dma_buf_import_modifiers EGL_EXT_yuv_surface
    EGL_EXT_pixel_format_float EGL_ARM_pixmap_multisample_discard
    EGL_KHR_gl_texture_2D_image EGL_KHR_gl_renderbuffer_image
    EGL_KHR_create_context EGL_KHR_surfaceless_context
    EGL_KHR_gl_texture_cubemap_image EGL_EXT_image_gl_colorspace
    EGL_EXT_create_context_robustness
Configurations:
     bf lv colorbuffer dp st  ms    vis   cav bi  renderable  supported
  id sz  l  r  g  b  a th cl ns b    id   eat nd gl es es2 vg surfaces
---------------------------------------------------------------------
0x01 32  0  8  8  8  8  0  0  0 0 0x67TC      a     y  y     win,pb,pix
0x02 32  0  8  8  8  8 24  0  0 0 0x67TC      a     y  y     win,pb,pix
0x03 32  0  8  8  8  8 24  8  0 0 0x67TC      a     y  y     win,pb,pix
0x04 32  0  8  8  8  8 24  8  4 1 0x67TC      a     y  y     win,pb,pix
0x05 16  0  5  6  5  0  0  0  0 0 0x00--      y     y  y     pb,pix
0x06 16  0  5  6  5  0 24  0  0 0 0x00--      y     y  y     pb,pix
0x07 16  0  5  6  5  0 24  8  0 0 0x00--      y     y  y     pb,pix
0x08 16  0  5  6  5  0 24  8  4 1 0x00--      y     y  y     pb,pix
0x09 24  0  8  8  8  0  0  0  0 0 0x21TC      y     y  y     win,pb,pix
0x0a 24  0  8  8  8  0 24  8  0 0 0x21TC      y     y  y     win,pb,pix
0x0b 24  0  8  8  8  0  0  0  4 1 0x21TC      y     y  y     win,pb,pix
0x0c 24  0  8  8  8  0 24  8  4 1 0x21TC      y     y  y     win,pb,pix
0x0d 16  0  5  5  5  1 24  8  0 0 0x00--      a     y  y     pb,pix
0x0e 16  0  5  5  5  1 24  8  4 1 0x00--      a     y  y     pb,pix
0x0f 16  0  4  4  4  4 24  8  0 0 0x00--      a     y  y     pb,pix
0x10 16  0  4  4  4  4 24  8  4 1 0x00--      a     y  y     pb,pix
0x11 32  0  8  8  8  8 24  8  8 1 0x67TC      a     y  y     win,pb,pix
0x12 16  0  5  6  5  0 24  8  8 1 0x00--      y     y  y     pb,pix
0x13 24  0  8  8  8  0 24  8  8 1 0x21TC      y     y  y     win,pb,pix
0x14 32  0  8  8  8  8 24  8 16 1 0x67TC      a     y  y     win,pb,pix
0x15 16  0  5  6  5  0 24  8 16 1 0x00--      y     y  y     pb,pix
0x16 24  0  8  8  8  0 24  8 16 1 0x21TC      y     y  y     win,pb,pix
0x17 24  0  8  8  8  0  0  0  0 0 0x21TC            y  y     win,pb,pix
0x18 64  0 16 16 16 16 24  8  0 0 0x00--            y  y     pb
0x19 32  0 10 10 10  2 24  8  0 0 0x00--      a     y  y     pb,pix
0x1a 24  0  8  8  8  0  0  0  0 0 0x21TC      y     y  y     win,pb,pix

orangepi@orangepi5:~$

cnxの記事でglmark2-es2-waylandを使ってベンチマークとってるので、マネして「sudo apt install glmark2-es2-wayland」でベンチマークソフトをインストールして実行

orangepi@orangepi5:~$ glmark2-es2-wayland
Error: main: Could not initialize canvas
orangepi@orangepi5:~$

Orange PI 5 Ubuntu環境では実行できない

よくよく確認してみるとX-waylandを使用していないので「glmark2-es2」を実行。

orangepi@orangepi5:~$ glmark2-es2
arm_release_ver of this libmali is 'g6p0-01eac0', rk_so_ver is '5'.
arm_release_ver of this libmali is 'g6p0-01eac0', rk_so_ver is '5'.
=======================================================
    glmark2 2021.02
=======================================================
    OpenGL Information
    GL_VENDOR:     ARM
    GL_RENDERER:   Mali-LODX
    GL_VERSION:    OpenGL ES 3.2 v1.g6p0-01eac0.efb75e2978d783a80fe78be1bfb0efc1
=======================================================
[build] use-vbo=false: FPS: 688 FrameTime: 1.453 ms
[build] use-vbo=true: FPS: 855 FrameTime: 1.170 ms
[texture] texture-filter=nearest: FPS: 899 FrameTime: 1.112 ms
[texture] texture-filter=linear: FPS: 859 FrameTime: 1.164 ms
[texture] texture-filter=mipmap: FPS: 848 FrameTime: 1.179 ms
[shading] shading=gouraud: FPS: 904 FrameTime: 1.106 ms
[shading] shading=blinn-phong-inf: FPS: 886 FrameTime: 1.129 ms
[shading] shading=phong: FPS: 814 FrameTime: 1.229 ms
[shading] shading=cel: FPS: 789 FrameTime: 1.267 ms
[bump] bump-render=high-poly: FPS: 552 FrameTime: 1.812 ms
[bump] bump-render=normals: FPS: 952 FrameTime: 1.050 ms
[bump] bump-render=height: FPS: 900 FrameTime: 1.111 ms
[effect2d] kernel=0,1,0;1,-4,1;0,1,0;: FPS: 973 FrameTime: 1.028 ms
[effect2d] kernel=1,1,1,1,1;1,1,1,1,1;1,1,1,1,1;: FPS: 746 FrameTime: 1.340 ms
[pulsar] light=false:quads=5:texture=false: FPS: 973 FrameTime: 1.028 ms
[desktop] blur-radius=5:effect=blur:passes=1:separable=true:windows=4: FPS: 482 FrameTime: 2.075 ms
[desktop] effect=shadow:windows=4: FPS: 785 FrameTime: 1.274 ms
[buffer] columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=map: FPS: 222 FrameTime: 4.505 ms
[buffer] columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=subdata: FPS: 194 FrameTime: 5.155 ms
[buffer] columns=200:interleave=true:update-dispersion=0.9:update-fraction=0.5:update-method=map: FPS: 354 FrameTime: 2.825 ms
[ideas] speed=duration: FPS: 491 FrameTime: 2.037 ms
[jellyfish] <default>: FPS: 696 FrameTime: 1.437 ms
[terrain] <default>: FPS: 186 FrameTime: 5.376 ms
[shadow] <default>: FPS: 732 FrameTime: 1.366 ms
[refract] <default>: FPS: 301 FrameTime: 3.322 ms
[conditionals] fragment-steps=0:vertex-steps=0: FPS: 874 FrameTime: 1.144 ms
[conditionals] fragment-steps=5:vertex-steps=0: FPS: 837 FrameTime: 1.195 ms
[conditionals] fragment-steps=0:vertex-steps=5: FPS: 802 FrameTime: 1.247 ms
[function] fragment-complexity=low:fragment-steps=5: FPS: 868 FrameTime: 1.152 ms
[function] fragment-complexity=medium:fragment-steps=5: FPS: 788 FrameTime: 1.269 ms
[loop] fragment-loop=false:fragment-steps=5:vertex-steps=5: FPS: 877 FrameTime: 1.140 ms
[loop] fragment-steps=5:fragment-uniform=false:vertex-steps=5: FPS: 833 FrameTime: 1.200 ms
[loop] fragment-steps=5:fragment-uniform=true:vertex-steps=5: FPS: 820 FrameTime: 1.220 ms
=======================================================
                                  glmark2 Score: 720
=======================================================
orangepi@orangepi5:~$

glmark2の場合はどうなるかを確認

orangepi@orangepi5:~$ glmark2
libGL error: failed to create dri screen
libGL error: failed to load driver: rockchip
libGL error: failed to create dri screen
libGL error: failed to load driver: rockchip
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
=======================================================
    glmark2 2021.02
=======================================================
    OpenGL Information
    GL_VENDOR:     Mesa/X.org
    GL_RENDERER:   llvmpipe (LLVM 13.0.1, 128 bits)
    GL_VERSION:    4.5 (Compatibility Profile) Mesa 22.0.5
=======================================================
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[build] use-vbo=false: FPS: 111 FrameTime: 9.009 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[build] use-vbo=true: FPS: 112 FrameTime: 8.929 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[texture] texture-filter=nearest: FPS: 325 FrameTime: 3.077 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[texture] texture-filter=linear: FPS: 246 FrameTime: 4.065 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[texture] texture-filter=mipmap: FPS: 191 FrameTime: 5.236 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[shading] shading=gouraud: FPS: 85 FrameTime: 11.765 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[shading] shading=blinn-phong-inf: FPS: 75 FrameTime: 13.333 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[shading] shading=phong: FPS: 62 FrameTime: 16.129 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[shading] shading=cel: FPS: 69 FrameTime: 14.493 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[bump] bump-render=high-poly: FPS: 40 FrameTime: 25.000 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[bump] bump-render=normals: FPS: 278 FrameTime: 3.597 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[bump] bump-render=height: FPS: 291 FrameTime: 3.436 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[effect2d] kernel=0,1,0;1,-4,1;0,1,0;: FPS: 114 FrameTime: 8.772 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[effect2d] kernel=1,1,1,1,1;1,1,1,1,1;1,1,1,1,1;: FPS: 99 FrameTime: 10.101 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[pulsar] light=false:quads=5:texture=false: FPS: 213 FrameTime: 4.695 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[desktop] blur-radius=5:effect=blur:passes=1:separable=true:windows=4: FPS: 25 FrameTime: 40.000 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[desktop] effect=shadow:windows=4: FPS: 65 FrameTime: 15.385 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[buffer] columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=map: FPS: 65 FrameTime: 15.385 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[buffer] columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=subdata: FPS: 67 FrameTime: 14.925 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[buffer] columns=200:interleave=true:update-dispersion=0.9:update-fraction=0.5:update-method=map: FPS: 66 FrameTime: 15.152 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[ideas] speed=duration: FPS: 80 FrameTime: 12.500 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[jellyfish] <default>: FPS: 57 FrameTime: 17.544 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[terrain] <default>: FPS: 3 FrameTime: 333.333 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[shadow] <default>: FPS: 54 FrameTime: 18.519 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[refract] <default>: FPS: 9 FrameTime: 111.111 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[conditionals] fragment-steps=0:vertex-steps=0: FPS: 139 FrameTime: 7.194 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[conditionals] fragment-steps=5:vertex-steps=0: FPS: 137 FrameTime: 7.299 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[conditionals] fragment-steps=0:vertex-steps=5: FPS: 140 FrameTime: 7.143 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[function] fragment-complexity=low:fragment-steps=5: FPS: 98 FrameTime: 10.204 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[function] fragment-complexity=medium:fragment-steps=5: FPS: 101 FrameTime: 9.901 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[loop] fragment-loop=false:fragment-steps=5:vertex-steps=5: FPS: 129 FrameTime: 7.752 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[loop] fragment-steps=5:fragment-uniform=false:vertex-steps=5: FPS: 135 FrameTime: 7.407 ms
** GLX does not support GLX_EXT_swap_control or GLX_MESA_swap_control!
** Failed to set swap interval. Results may be bounded above by refresh rate.
[loop] fragment-steps=5:fragment-uniform=true:vertex-steps=5: FPS: 128 FrameTime: 7.812 ms
=======================================================
                                  glmark2 Score: 115
=======================================================
orangepi@orangepi5:~$

glmark2の方だとうまく動いてないようだ。

次に、ChromiumブラウザでWebGL Aquariumを開いてみると「fps 3」という数字。めっちゃカクカクしている。

cnxsoftwareのRK3588関連記事を探してみると「Rock 5B RK3588 SBC preview – What works, what doesn’t in Debian 11」に「GPU 3D acceleration is not enabled in Debian 11」という話がある。

上の方にあるglxinfo結果のように「Device: llvmpipe (LLVM 13.0.1, 128 bits) (0xffffffff)」と「llvmpipe 」が含まれている場合はソフトウェアレンダリングである、とのこと。

「dmesg|grep -i mali」を実行して起動時にGPUドライバmaliが読み込まれているかを確認してみると、エラーっぽい感じの出力となっている。

orangepi@orangepi5:~$ dmesg|grep -i mali
[    7.672628] mali fb000000.gpu: Kernel DDK version g13p0-01eac0
[    7.672650] mali fb000000.gpu: Looking up mali-supply from device tree
[    7.673153] mali fb000000.gpu: Looking up mem-supply from device tree
[    7.676448] mali fb000000.gpu: Looking up mali-supply from device tree
[    7.676724] mali fb000000.gpu: Looking up mem-supply from device tree
[    7.676911] mali fb000000.gpu: Looking up mali-supply from device tree
[    7.677340] mali fb000000.gpu: leakage=12
[    7.677395] mali fb000000.gpu: Looking up mali-supply from device tree
[    7.677419] debugfs: Directory 'fb000000.gpu-mali' with parent 'vdd_gpu_s0' already present!
[    7.679307] mali fb000000.gpu: pvtm=869
[    7.679356] mali fb000000.gpu: pvtm-volt-sel=3
[    7.680674] mali fb000000.gpu: avs=0
[    7.682511] W : [File] : drivers/gpu/arm/bifrost/platform/rk/mali_kbase_config_rk.c; [Line] : 136; [Func] : kbase_platform_rk_init(); power-off-delay-ms not available.
[    7.689235] mali fb000000.gpu: GPU hardware issue table may need updating:
[    7.689246] mali fb000000.gpu: GPU identified as 0x7 arch 10.8.6 r0p0 status 0
[    7.689340] mali fb000000.gpu: No priority control manager is configured
[    7.689348] mali fb000000.gpu: No memory group manager is configured
[    7.689378] mali fb000000.gpu: Protected memory allocator not available
[    7.689818] mali fb000000.gpu: Capping CSF_FIRMWARE_TIMEOUT to CSF_FIRMWARE_PING_TIMEOUT
[    7.690655] mali fb000000.gpu: Couldn't find power_model DT node matching 'arm,mali-simple-power-model'
[    7.690666] mali fb000000.gpu: Error -22, no DT entry: mali-simple-power-model.static-coefficient = 1*[0]
[    7.690992] mali fb000000.gpu: Error -22, no DT entry: mali-simple-power-model.dynamic-coefficient = 1*[0]
[    7.691272] mali fb000000.gpu: Error -22, no DT entry: mali-simple-power-model.ts = 4*[0]
[    7.691552] mali fb000000.gpu: Error -22, no DT entry: mali-simple-power-model.thermal-zone = ''
[    7.695409] mali fb000000.gpu: Using configured power model mali-lodx-power-model, and fallback mali-simple-power-model
[    7.695604] mali fb000000.gpu: l=10000 h=85000 hyst=5000 l_limit=0 h_limit=800000000 h_table=0
[    7.696563] mali fb000000.gpu: Probed as mali0
[    7.782056] I : [File] : drivers/gpu/arm/mali400/mali/linux/mali_kernel_linux.c; [Line] : 405; [Func] : mali_module_init(); svn_rev_string_from_arm of this mali_ko is '', rk_ko_ver is '5', built at '10:16:11', on 'Dec  7 2022'.
[    7.782364] Mali:
[    7.782367] Mali device driver loaded
[   16.423617] mali fb000000.gpu: Loading Mali firmware 0x1010000
[   16.425057] mali fb000000.gpu: Mali firmware git_sha: e6cfd856a9b143e1ab6657328e8b5ffc44a623f9
orangepi@orangepi5:~$

libmali-valhall-g610-g6p0-x11-gbm はインストールされている。

orangepi@orangepi5:~$ apt search libmali
Sorting... Done
Full Text Search... Done
libmali-valhall-g610-g6p0-x11-gbm/now 1.9-1 arm64 [installed,local]
  Mali GPU User-Space Binary Drivers

orangepi@orangepi5:~$

改善方法の試行

GPUに関する処理が改善できるのかを調査。

同じSoCを使うRock 5に関するフォーラムに「Best way to run GPU-accelerated applications」という記事があり、Panfrost GPU driverというものがあげられていた。

Ubuntu 22.02に対してインストールする場合の事例は「Ubuntu 20.02 & Mali Drivers」にあり、Ubutuのppaに登録されている panfork mesa to support mali g610 を利用する、というものである。

このPanfrost driverを適用するというのが、冒頭の「OrangePi5の公式xfceイメージにビデオドライバーをあてる」の内容である。

ただ、このPanfrostさん、行いに問題があるようでarmbianにこのppaを登録して欲しいというpull requestが拒否られています。( add panfork-mesa appgroup for jammy #4476 )

なんでもfork元のfreedesktop.orgでの行いに問題があってアカウントがbanされたんだとか・・・

なので、使うのはどうなのかなぁ、と思いつつとりあえず速度改善するのかどうかを確認してみることにします。

まずは「sudo add-apt-repository ppa:liujianfeng1994/panfork-mesa」を実行して、panfork mesa to support mali g610を登録します。

orangepi@orangepi5:~$ sudo add-apt-repository ppa:liujianfeng1994/panfork-mesa
Repository: 'deb https://ppa.launchpadcontent.net/liujianfeng1994/panfork-mesa/ubuntu/ jammy main'
Description:
https://gitlab.com/panfork/mesa
You need to download mali firmware from https://github.com/JeffyCN/rockchip_mirrors/raw/libmali/firmware/g610/mali_csffw.bin and copy it to /lib/firmware/
More info: https://launchpad.net/~liujianfeng1994/+archive/ubuntu/panfork-mesa
Adding repository.
Press [ENTER] to continue or Ctrl-c to cancel.
Adding deb entry to /etc/apt/sources.list.d/liujianfeng1994-ubuntu-panfork-mesa-jammy.list
Adding disabled deb-src entry to /etc/apt/sources.list.d/liujianfeng1994-ubuntu-panfork-mesa-jammy.list
Adding key to /etc/apt/trusted.gpg.d/liujianfeng1994-ubuntu-panfork-mesa.gpg with fingerprint 0B2F0747E3BD546820A639B68065BE1FC67AABDE
Hit:1 http://repo.huaweicloud.com/ubuntu-ports jammy InRelease
Hit:2 http://repo.huaweicloud.com/ubuntu-ports jammy-security InRelease
Hit:3 https://repo.huaweicloud.com/docker-ce/linux/ubuntu jammy InRelease
Hit:4 http://repo.huaweicloud.com/ubuntu-ports jammy-updates InRelease
Get:5 https://ppa.launchpadcontent.net/liujianfeng1994/panfork-mesa/ubuntu jammy InRelease [18.1 kB]
Hit:6 http://repo.huaweicloud.com/ubuntu-ports jammy-backports InRelease
Get:7 https://ppa.launchpadcontent.net/liujianfeng1994/panfork-mesa/ubuntu jammy/main armhf Packages [4,136 B]
Get:8 https://ppa.launchpadcontent.net/liujianfeng1994/panfork-mesa/ubuntu jammy/main arm64 Packages [4,152 B]
Fetched 26.4 kB in 4s (6,080 B/s)
Reading package lists... Done
W: https://repo.huaweicloud.com/docker-ce/linux/ubuntu/dists/jammy/InRelease: Key is stored in legacy trusted.gpg keyring (/etc/apt/trusted.gpg), see the DEPRECATION section in apt-key(8) for details.
orangepi@orangepi5:~$

出力内に「You need to download mali firmware from https://github.com/JeffyCN/rockchip_mirrors/raw/libmali/firmware/g610/mali_csffw.bin and copy it to /lib/firmware/」とあるように、mali_csffw.bin を入れ替える必要があります。

orangepi@orangepi5:~$ ls -l /lib/firmware/*mali*
-rw-r--r-- 1 root root 266240 Jul 29  2020 /lib/firmware/mali_csffw.bin
orangepi@orangepi5:~$
orangepi@orangepi5:~$ sudo curl --output /lib/firmware/mali_csffw.bin https://raw.githubusercontent.com/JeffyCN/rockchip_mirrors/libmali/firmware/g610/mali_csffw.bin
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100  268k  100  268k    0     0  1319k      0 --:--:-- --:--:-- --:--:-- 1326k
orangepi@orangepi5:~$ ls -l /lib/firmware/*mali*
-rw-r--r-- 1 root root 274432 Dec 27 21:08 /lib/firmware/mali_csffw.bin
orangepi@orangepi5:~$

入れ替えたあとは「sudo apt update」でレポジトリの情報を更新します。

orangepi@orangepi5:~$ sudo apt update
Hit:1 http://repo.huaweicloud.com/ubuntu-ports jammy InRelease
Hit:2 http://repo.huaweicloud.com/ubuntu-ports jammy-security InRelease
Hit:3 http://repo.huaweicloud.com/ubuntu-ports jammy-updates InRelease
Hit:4 http://repo.huaweicloud.com/ubuntu-ports jammy-backports InRelease
Hit:5 https://repo.huaweicloud.com/docker-ce/linux/ubuntu jammy InRelease
Hit:6 https://ppa.launchpadcontent.net/liujianfeng1994/panfork-mesa/ubuntu jammy InRelease
Reading package lists... Done
Building dependency tree... Done
Reading state information... Done
33 packages can be upgraded. Run 'apt list --upgradable' to see them.
W: https://repo.huaweicloud.com/docker-ce/linux/ubuntu/dists/jammy/InRelease: Key is stored in legacy trusted.gpg keyring (/etc/apt/trusted.gpg), see the DEPRECATION section in apt-key(8) for details.
orangepi@orangepi5:~$

どんなアップデートがあるのか「apt list –upgradable」を実行して確認すると、いくつかのライブラリなどが更新対象となるようだ。

orangepi@orangepi5:~$ apt list --upgradable
Listing... Done
ffmpeg/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
gstreamer1.0-tools/jammy-updates 1.20.3-0ubuntu1 arm64 [upgradable from: 1.20.3-0ubuntu1]
libavcodec-dev/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libavcodec58/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libavdevice-dev/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libavdevice58/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libavfilter-dev/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libavfilter7/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libavformat-dev/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libavformat58/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libavutil-dev/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libavutil56/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libdvbv5-0/jammy 1.22.1-2build1 arm64 [upgradable from: 1.22.1-2build1]
libegl-mesa0/jammy 23.0~panfork~csf~git221210.120202c6757~j arm64 [upgradable from: 22.0.5-0ubuntu0.1]
libgbm-dev/jammy 23.0~panfork~csf~git221210.120202c6757~j arm64 [upgradable from: 22.0.5-0ubuntu0.1]
libgbm1/jammy 23.0~panfork~csf~git221210.120202c6757~j arm64 [upgradable from: 22.0.5-0ubuntu0.1]
libgl1-mesa-dri/jammy 23.0~panfork~csf~git221210.120202c6757~j arm64 [upgradable from: 22.0.5-0ubuntu0.1]
libglapi-mesa/jammy 23.0~panfork~csf~git221210.120202c6757~j arm64 [upgradable from: 22.0.5-0ubuntu0.1]
libglx-mesa0/jammy 23.0~panfork~csf~git221210.120202c6757~j arm64 [upgradable from: 22.0.5-0ubuntu0.1]
libgstreamer1.0-0/jammy-updates 1.20.3-0ubuntu1 arm64 [upgradable from: 1.20.3-0ubuntu1]
libmpv1/jammy 0.34.1-1ubuntu3 arm64 [upgradable from: 0.34.1-1ubuntu3]
libpostproc55/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libswresample-dev/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libswresample3/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
libswscale5/jammy-security,jammy-updates 7:4.4.2-0ubuntu0.22.04.1 arm64 [upgradable from: 7:4.4.2-0ubuntu0.22.04.1]
mesa-common-dev/jammy 23.0~panfork~csf~git221210.120202c6757~j arm64 [upgradable from: 22.0.5-0ubuntu0.1]
mpv/jammy 0.34.1-1ubuntu3 arm64 [upgradable from: 0.34.1-1ubuntu3]
v4l-utils/jammy 1.22.1-2build1 arm64 [upgradable from: 1.22.1-2build1]
wiringpi/jammy 2.50-0ubuntu2 arm64 [upgradable from: 2.46]
xserver-common/jammy-security,jammy-security,jammy-updates,jammy-updates 2:21.1.3-2ubuntu2.5 all [upgradable from: 2:21.1.3-2ubuntu2]
xserver-xorg-core/jammy-security,jammy-updates 2:21.1.3-2ubuntu2.5 arm64 [upgradable from: 2:21.1.3-2ubuntu2]
xserver-xorg-dev/jammy-security,jammy-updates 2:21.1.3-2ubuntu2.5 arm64 [upgradable from: 2:21.1.3-2ubuntu2]
xserver-xorg-legacy/jammy-security,jammy-updates 2:21.1.3-2ubuntu2.5 arm64 [upgradable from: 2:21.1.3-2ubuntu2]
orangepi@orangepi5:~$

で「sudo apt upgrade -y」を実行してアップデートを適用して、再起動します。

適用後の状況

ChromiumブラウザでWebGL Aquariumが「fps:60」で動作するようになりました

これはと思って他をいろいろチェック・・・

orangepi@orangepi5:~$ glxinfo -B
name of display: :0
display: :0  screen: 0
direct rendering: Yes
Extended renderer info (GLX_MESA_query_renderer):
    Vendor: Panfrost (0xffffffff)
    Device: Mali-G610 (Panfrost) (0xffffffff)
    Version: 23.0.0
    Accelerated: yes
    Video memory: 7689MB
    Unified memory: yes
    Preferred profile: compat (0x2)
    Max core profile version: 0.0
    Max compat profile version: 3.0
    Max GLES1 profile version: 1.1
    Max GLES[23] profile version: 3.1
OpenGL vendor string: Panfrost
OpenGL renderer string: Mali-G610 (Panfrost)
OpenGL version string: 3.0 Mesa 23.0.0-devel
OpenGL shading language version string: 1.30
OpenGL context flags: (none)

OpenGL ES profile version string: OpenGL ES 3.1 Mesa 23.0.0-devel
OpenGL ES profile shading language version string: OpenGL ES GLSL ES 3.10

orangepi@orangepi5:~$

glxinfoの結果でllvmpipe がなくなり、「OpenGL renderer string: Mali-G610 (Panfrost)」となっている。

orangepi@orangepi5:~$ inxi -Fc0
System:
  Host: orangepi5 Kernel: 5.10.110-rockchip-rk3588 aarch64 bits: 64
    Desktop: Xfce 4.16.0 Distro: Ubuntu 22.04.1 LTS (Jammy Jellyfish)
Machine:
  Type: ARM System: Orange Pi 5 details: N/A
CPU:
  Info: 3x 4-core model: N/A variant-1: cortex-a55 variant-2: cortex-a76
    bits: 64 type: MCP AMP cache: L2: 3x 512 KiB (1.5 MiB)
  Speed (MHz): avg: 408 min/max: 408/1800:2400 cores: 1: 408 2: 408 3: 408
    4: 408 5: 408 6: 408 7: 408 8: 408
Graphics:
  Device-1: display-subsystem driver: rockchip_drm v: N/A
  Device-2: mali-bifrost driver: mali v: N/A
  Device-3: rk3588-dw-hdmi driver: dwhdmi_rockchip v: N/A
  Display: server: X.Org v: 1.21.1.3 driver: X: loaded: modesetting
    gpu: rockchip_drm,mali,dwhdmi_rockchip resolution: 1920x1080~60Hz
  OpenGL: renderer: Mali-G610 (Panfrost) v: 3.0 Mesa 23.0.0-devel
Audio:
  Device-1: hdmi driver: rk_hdmi_sound
  Device-2: rk3588-dw-hdmi driver: dwhdmi_rockchip
  Device-3: hdmi driver: rk_hdmi_sound
  Sound Server-1: ALSA v: k5.10.110-rockchip-rk3588 running: yes
  Sound Server-2: PulseAudio v: 15.99.1 running: yes
Network:
  Device-1: rk3588-gmac driver: rk_gmac_dwmac
  IF: eth0 state: up speed: 1000 Mbps duplex: full mac: 7e:2c:10:9c:32:61
Drives:
  Local Storage: total: 29.9 GiB used: 5 GiB (16.7%)
  ID-1: /dev/mmcblk1 model: 5cMJR size: 29.9 GiB
Partition:
  ID-1: / size: 29.14 GiB used: 4.9 GiB (16.8%) fs: ext4 dev: /dev/mmcblk1p2
  ID-2: /boot size: 255.7 MiB used: 94.2 MiB (36.8%) fs: vfat
    dev: /dev/mmcblk1p1
  ID-3: /var/log size: 187.3 MiB used: 4.5 MiB (2.4%) fs: ext4
    dev: /dev/zram1
Swap:
  ID-1: swap-1 type: zram size: 3.75 GiB used: 0 KiB (0.0%) dev: /dev/zram0
Sensors:
  System Temperatures: cpu: 45.3 C mobo: N/A
  Fan Speeds (RPM): N/A
Info:
  Processes: 263 Uptime: 1m Memory: 7.51 GiB used: 706.6 MiB (9.2%)
  Shell: Bash inxi: 3.3.13
orangepi@orangepi5:~$
orangepi@orangepi5:~$ eglinfo
EGL client extensions string:
    EGL_EXT_client_extensions EGL_EXT_platform_base
    EGL_KHR_client_get_all_proc_addresses EGL_KHR_platform_x11
    EGL_EXT_platform_x11 EGL_KHR_platform_gbm

GBM platform:
arm_release_ver of this libmali is 'g6p0-01eac0', rk_so_ver is '5'.
eglinfo: eglInitialize failed

X11 platform:
EGL API version: 1.4
EGL vendor string: ARM
EGL version string: 1.4 Valhall-"g6p0-01eac0"
EGL client APIs: OpenGL_ES
EGL extensions string:
    EGL_NV_context_priority_realtime EGL_KHR_image_pixmap
    EGL_KHR_partial_update EGL_EXT_image_dma_buf_import
    EGL_KHR_config_attribs EGL_KHR_image EGL_KHR_image_base
    EGL_KHR_fence_sync EGL_KHR_wait_sync EGL_KHR_gl_colorspace
    EGL_KHR_get_all_proc_addresses EGL_IMG_context_priority
    EGL_KHR_no_config_context EGL_EXT_image_dma_buf_import
    EGL_EXT_image_dma_buf_import_modifiers EGL_EXT_yuv_surface
    EGL_EXT_pixel_format_float EGL_ARM_pixmap_multisample_discard
    EGL_KHR_gl_texture_2D_image EGL_KHR_gl_renderbuffer_image
    EGL_KHR_create_context EGL_KHR_surfaceless_context
    EGL_KHR_gl_texture_cubemap_image EGL_EXT_image_gl_colorspace
    EGL_EXT_create_context_robustness
Configurations:
     bf lv colorbuffer dp st  ms    vis   cav bi  renderable  supported
  id sz  l  r  g  b  a th cl ns b    id   eat nd gl es es2 vg surfaces
---------------------------------------------------------------------
0x01 32  0  8  8  8  8  0  0  0 0 0x67TC      a     y  y     win,pb,pix
0x02 32  0  8  8  8  8 24  0  0 0 0x67TC      a     y  y     win,pb,pix
0x03 32  0  8  8  8  8 24  8  0 0 0x67TC      a     y  y     win,pb,pix
0x04 32  0  8  8  8  8 24  8  4 1 0x67TC      a     y  y     win,pb,pix
0x05 16  0  5  6  5  0  0  0  0 0 0x00--      y     y  y     pb,pix
0x06 16  0  5  6  5  0 24  0  0 0 0x00--      y     y  y     pb,pix
0x07 16  0  5  6  5  0 24  8  0 0 0x00--      y     y  y     pb,pix
0x08 16  0  5  6  5  0 24  8  4 1 0x00--      y     y  y     pb,pix
0x09 24  0  8  8  8  0  0  0  0 0 0x21TC      y     y  y     win,pb,pix
0x0a 24  0  8  8  8  0 24  8  0 0 0x21TC      y     y  y     win,pb,pix
0x0b 24  0  8  8  8  0  0  0  4 1 0x21TC      y     y  y     win,pb,pix
0x0c 24  0  8  8  8  0 24  8  4 1 0x21TC      y     y  y     win,pb,pix
0x0d 16  0  5  5  5  1 24  8  0 0 0x00--      a     y  y     pb,pix
0x0e 16  0  5  5  5  1 24  8  4 1 0x00--      a     y  y     pb,pix
0x0f 16  0  4  4  4  4 24  8  0 0 0x00--      a     y  y     pb,pix
0x10 16  0  4  4  4  4 24  8  4 1 0x00--      a     y  y     pb,pix
0x11 32  0  8  8  8  8 24  8  8 1 0x67TC      a     y  y     win,pb,pix
0x12 16  0  5  6  5  0 24  8  8 1 0x00--      y     y  y     pb,pix
0x13 24  0  8  8  8  0 24  8  8 1 0x21TC      y     y  y     win,pb,pix
0x14 32  0  8  8  8  8 24  8 16 1 0x67TC      a     y  y     win,pb,pix
0x15 16  0  5  6  5  0 24  8 16 1 0x00--      y     y  y     pb,pix
0x16 24  0  8  8  8  0 24  8 16 1 0x21TC      y     y  y     win,pb,pix
0x17 24  0  8  8  8  0  0  0  0 0 0x21TC            y  y     win,pb,pix
0x18 64  0 16 16 16 16 24  8  0 0 0x00--            y  y     pb
0x19 32  0 10 10 10  2 24  8  0 0 0x00--      a     y  y     pb,pix
0x1a 24  0  8  8  8  0  0  0  0 0 0x21TC      y     y  y     win,pb,pix

orangepi@orangepi5:~$

で・・・「glmark2-es2」を実行してベンチマークをとってみる(cnxの記事だと glmark2-es2-wayland を実行しているが、wayland環境ではないので、 glmark2-es2を実行する)

orangepi@orangepi5:~$ glmark2-es2
arm_release_ver of this libmali is 'g6p0-01eac0', rk_so_ver is '5'.
arm_release_ver of this libmali is 'g6p0-01eac0', rk_so_ver is '5'.
=======================================================
    glmark2 2021.02
=======================================================
    OpenGL Information
    GL_VENDOR:     ARM
    GL_RENDERER:   Mali-LODX
    GL_VERSION:    OpenGL ES 3.2 v1.g6p0-01eac0.efb75e2978d783a80fe78be1bfb0efc1
=======================================================
[build] use-vbo=false: FPS: 718 FrameTime: 1.393 ms
[build] use-vbo=true: FPS: 850 FrameTime: 1.176 ms
[texture] texture-filter=nearest: FPS: 977 FrameTime: 1.024 ms
[texture] texture-filter=linear: FPS: 820 FrameTime: 1.220 ms
[texture] texture-filter=mipmap: FPS: 833 FrameTime: 1.200 ms
[shading] shading=gouraud: FPS: 804 FrameTime: 1.244 ms
[shading] shading=blinn-phong-inf: FPS: 789 FrameTime: 1.267 ms
[shading] shading=phong: FPS: 799 FrameTime: 1.252 ms
[shading] shading=cel: FPS: 798 FrameTime: 1.253 ms
[bump] bump-render=high-poly: FPS: 607 FrameTime: 1.647 ms
[bump] bump-render=normals: FPS: 897 FrameTime: 1.115 ms
[bump] bump-render=height: FPS: 898 FrameTime: 1.114 ms
[effect2d] kernel=0,1,0;1,-4,1;0,1,0;: FPS: 945 FrameTime: 1.058 ms
[effect2d] kernel=1,1,1,1,1;1,1,1,1,1;1,1,1,1,1;: FPS: 716 FrameTime: 1.397 ms
[pulsar] light=false:quads=5:texture=false: FPS: 958 FrameTime: 1.044 ms
[desktop] blur-radius=5:effect=blur:passes=1:separable=true:windows=4: FPS: 479 FrameTime: 2.088 ms
[desktop] effect=shadow:windows=4: FPS: 702 FrameTime: 1.425 ms
[buffer] columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=map: FPS: 195 FrameTime: 5.128 ms
[buffer] columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=subdata: FPS: 193 FrameTime: 5.181 ms
[buffer] columns=200:interleave=true:update-dispersion=0.9:update-fraction=0.5:update-method=map: FPS: 348 FrameTime: 2.874 ms
[ideas] speed=duration: FPS: 475 FrameTime: 2.105 ms
[jellyfish] <default>: FPS: 723 FrameTime: 1.383 ms
[terrain] <default>: FPS: 184 FrameTime: 5.435 ms
[shadow] <default>: FPS: 716 FrameTime: 1.397 ms
[refract] <default>: FPS: 292 FrameTime: 3.425 ms
[conditionals] fragment-steps=0:vertex-steps=0: FPS: 880 FrameTime: 1.136 ms
[conditionals] fragment-steps=5:vertex-steps=0: FPS: 810 FrameTime: 1.235 ms
[conditionals] fragment-steps=0:vertex-steps=5: FPS: 804 FrameTime: 1.244 ms
[function] fragment-complexity=low:fragment-steps=5: FPS: 862 FrameTime: 1.160 ms
[function] fragment-complexity=medium:fragment-steps=5: FPS: 832 FrameTime: 1.202 ms
[loop] fragment-loop=false:fragment-steps=5:vertex-steps=5: FPS: 800 FrameTime: 1.250 ms
[loop] fragment-steps=5:fragment-uniform=false:vertex-steps=5: FPS: 749 FrameTime: 1.335 ms
[loop] fragment-steps=5:fragment-uniform=true:vertex-steps=5: FPS: 817 FrameTime: 1.224 ms
=======================================================
                                  glmark2 Score: 705
=======================================================
orangepi@orangepi5:~$

glmark2-esの標準時の「glmark2 Score: 720」から下がってしまったという・・・

そして、glmark2

orangepi@orangepi5:~$ glmark2
=======================================================
    glmark2 2021.02
=======================================================
    OpenGL Information
    GL_VENDOR:     Panfrost
    GL_RENDERER:   Mali-G610 (Panfrost)
    GL_VERSION:    3.0 Mesa 23.0.0-devel
=======================================================
[build] use-vbo=false:Queue group error: status 0x24c00488 sideband 0x140947fbf
syncobj 0x5598b328f0 wait timeout
CSI 0 CS_EXTRACT (9664) != 9856, CS_ACTIVE (0)
fences:
 slot 3: seqnum 51
 slot 2: seqnum 51
syncobj 0x5598b328f0 wait timeout
CSI 1 CS_EXTRACT (12864) != 13120, CS_ACTIVE (0)
fences:
 slot 3: seqnum 51
 slot 2: seqnum 51
MESA: error: Context reset
bound csi 0 again
bound csi 1 again
Queue group error: status 0x24c00488 sideband 0x124b794ff
syncobj 0x5598b328f0 wait timeout
CSI 0 CS_EXTRACT (13120) != 13312, CS_ACTIVE (0)
fences:
 slot 3: seqnum 69
 slot 2: seqnum 69
syncobj 0x5598b328f0 wait timeout
CSI 1 CS_EXTRACT (17472) != 17728, CS_ACTIVE (0)
fences:
 slot 3: seqnum 69
 slot 2: seqnum 69
MESA: error: Context reset
bound csi 0 again
bound csi 1 again
 FPS: 156 FrameTime: 6.410 ms
[build] use-vbo=true: FPS: 492 FrameTime: 2.033 ms
[texture] texture-filter=nearest: FPS: 451 FrameTime: 2.217 ms
[texture] texture-filter=linear: FPS: 458 FrameTime: 2.183 ms
[texture] texture-filter=mipmap: FPS: 463 FrameTime: 2.160 ms
[shading] shading=gouraud: FPS: 444 FrameTime: 2.252 ms
[shading] shading=blinn-phong-inf: FPS: 237 FrameTime: 4.219 ms
[shading] shading=phong: FPS: 431 FrameTime: 2.320 ms
[shading] shading=cel: FPS: 454 FrameTime: 2.203 ms
[bump] bump-render=high-poly: FPS: 572 FrameTime: 1.748 ms
[bump] bump-render=normals: FPS: 658 FrameTime: 1.520 ms
[bump] bump-render=height: FPS: 652 FrameTime: 1.534 ms
[effect2d] kernel=0,1,0;1,-4,1;0,1,0;: FPS: 659 FrameTime: 1.517 ms
[effect2d] kernel=1,1,1,1,1;1,1,1,1,1;1,1,1,1,1;: FPS: 538 FrameTime: 1.859 ms
[pulsar] light=false:quads=5:texture=false: FPS: 569 FrameTime: 1.757 ms
[desktop] blur-radius=5:effect=blur:passes=1:separable=true:windows=4: FPS: 196 FrameTime: 5.102 ms
[desktop] effect=shadow:windows=4: FPS: 471 FrameTime: 2.123 ms
[buffer] columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=map: FPS: 303 FrameTime: 3.300 ms
[buffer] columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=subdata: FPS: 291 FrameTime: 3.436 ms
[buffer] columns=200:interleave=true:update-dispersion=0.9:update-fraction=0.5:update-method=map: FPS: 313 FrameTime: 3.195 ms
[ideas] speed=duration: FPS: 243 FrameTime: 4.115 ms
[jellyfish] <default>: FPS: 476 FrameTime: 2.101 ms
[terrain] <default>: FPS: 57 FrameTime: 17.544 ms
[shadow] <default>: FPS: 347 FrameTime: 2.882 ms
[refract] <default>: FPS: 275 FrameTime: 3.636 ms
[conditionals] fragment-steps=0:vertex-steps=0: FPS: 599 FrameTime: 1.669 ms
[conditionals] fragment-steps=5:vertex-steps=0: FPS: 391 FrameTime: 2.558 ms
[conditionals] fragment-steps=0:vertex-steps=5: FPS: 382 FrameTime: 2.618 ms
[function] fragment-complexity=low:fragment-steps=5: FPS: 390 FrameTime: 2.564 ms
[function] fragment-complexity=medium:fragment-steps=5: FPS: 376 FrameTime: 2.660 ms
[loop] fragment-loop=false:fragment-steps=5:vertex-steps=5: FPS: 384 FrameTime: 2.604 ms
[loop] fragment-steps=5:fragment-uniform=false:vertex-steps=5: FPS: 361 FrameTime: 2.770 ms
[loop] fragment-steps=5:fragment-uniform=true:vertex-steps=5: FPS: 293 FrameTime: 3.413 ms
=======================================================
                                  glmark2 Score: 405
=======================================================
orangepi@orangepi5:~$

スコアは標準の115から405へと躍進していますが、実際に表示された画面は、馬が変な状態でフリーズしたまま、GUIが全部とまりましたので、Panrost GPUドライバ自体の動きが非常に怪しいようです。

というわけで、ブラウザ表示の高速化であれば大丈夫そうですが、ちゃんとGPUを使っていこうとすると、問題が出たりしそうです。