From nobody Wed Jan 26 00:36:29 2022 X-Original-To: freebsd-arm@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 1F5F8196F76E for ; Wed, 26 Jan 2022 00:36:35 +0000 (UTC) (envelope-from kiri@truefc.org) Received: from kx.truefc.org (1.212.52.36.ap.yournet.ne.jp [36.52.212.1]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (2048 bits) client-digest SHA256) (Client CN "smtp", Issuer "smtp" (not verified)) by mx1.freebsd.org (Postfix) with ESMTPS id 4Jk4Xd36zzz3kfm; Wed, 26 Jan 2022 00:36:32 +0000 (UTC) (envelope-from kiri@truefc.org) Received: from kx.truefc.org (kx.truefc.org [36.52.212.1]) by kx.truefc.org (8.16.1/8.16.1) with ESMTP id 20Q0aTcm071987; Wed, 26 Jan 2022 09:36:29 +0900 (JST) (envelope-from kiri@kx.truefc.org) Message-Id: <202201260036.20Q0aTcm071987@kx.truefc.org> Date: Wed, 26 Jan 2022 09:36:29 +0900 From: KIRIYAMA Kazuhiko To: Jesper Schmitz Mouridsen Cc: KIRIYAMA Kazuhiko , freebsd-arm@freebsd.org Subject: Re: Failed boot at drm_vblank in arm64/aarch64 on PBP In-Reply-To: <68641063-f78c-743b-d528-348d6ffdecab@FreeBSD.org> References: <202201250215.20P2FSFU038389@kx.truefc.org> <68641063-f78c-743b-d528-348d6ffdecab@FreeBSD.org> User-Agent: Wanderlust/2.15.9 (Almost Unreal) SEMI/1.14.6 (Maruoka) FLIM/1.14.9 (=?ISO-8859-4?Q?Goj=F2?=) APEL/10.8 MULE XEmacs/21.4 (patch 24) (Standard C) (amd64--freebsd) List-Id: Porting FreeBSD to ARM processors List-Archive: https://lists.freebsd.org/archives/freebsd-arm List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-freebsd-arm@freebsd.org MIME-Version: 1.0 (generated by SEMI 1.14.6 - "Maruoka") Content-Type: text/plain; charset=US-ASCII X-Rspamd-Queue-Id: 4Jk4Xd36zzz3kfm X-Spamd-Bar: -- Authentication-Results: mx1.freebsd.org; dkim=none; dmarc=none; spf=pass (mx1.freebsd.org: domain of kiri@truefc.org designates 36.52.212.1 as permitted sender) smtp.mailfrom=kiri@truefc.org X-Spamd-Result: default: False [-2.95 / 15.00]; ARC_NA(0.00)[]; NEURAL_HAM_MEDIUM(-1.00)[-1.000]; FREEFALL_USER(0.00)[kiri]; RCPT_COUNT_THREE(0.00)[3]; TO_DN_SOME(0.00)[]; R_SPF_ALLOW(-0.20)[+ip4:36.52.212.0/29]; FROM_HAS_DN(0.00)[]; MIME_GOOD(-0.10)[text/plain]; DMARC_NA(0.00)[truefc.org]; NEURAL_HAM_LONG(-1.00)[-1.000]; TO_MATCH_ENVRCPT_SOME(0.00)[]; MID_RHS_MATCH_FROMTLD(0.00)[]; NEURAL_HAM_SHORT(-0.85)[-0.846]; RCVD_COUNT_ONE(0.00)[1]; MLMMJ_DEST(0.00)[freebsd-arm]; RCVD_NO_TLS_LAST(0.10)[]; FROM_EQ_ENVFROM(0.00)[]; R_DKIM_NA(0.00)[]; MIME_TRACE(0.00)[0:+]; ASN(0.00)[asn:10013, ipnet:36.52.208.0/21, country:JP]; ONCE_RECEIVED(0.10)[] X-ThisMailContainsUnwantedMimeParts: N Hi, Jesper On Wed, 26 Jan 2022 03:45:05 +0900, Jesper Schmitz Mouridsen wrote: > > > > On 25.01.2022 03.15, KIRIYAMA Kazuhiko wrote: > > Hi, all > > > > I've re-made boot image for Pinebook Pro (PBP) of > > 14.0-CURRENT n252589-ece746877783 which is made by > > GENERIC-DRM kernel for Panfrost driver [1] : > > > > First `git subtree add' to 14.0-CURRENT (f72926eab00c) in src server : > > > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git checkout f72926eab00c > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git remote add drm-subtree https://github.com/jsm222/drm-subtree.git > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git subtree add --prefix sys/dev/drm/ drm-subtree pinebookpro-test > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git apply sys/dev/drm/extra_patches/0001-Hook-DRM-to-the-build.patch > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git apply sys/dev/drm/extra_patches/0002-Add-GENERIC-DRM-for-armv7.patch > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git apply sys/dev/drm/extra_patches/0003-drm-Add-rockchip-and-bridges-into-GENERIC-DRM.patch > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git apply sys/dev/drm/pbp-kernel-extra-patches/gicv3_its.c-patch > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git apply sys/dev/drm/pbp-kernel-extra-patches/mixer.c.patch > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git apply sys/dev/drm/pbp-kernel-extra-patches/sys_dev_iicbus_es8316.c > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git apply sys/dev/drm/pbp-kernel-extra-patches/GENERIC-DRM.patch > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git apply sys/dev/drm/pbp-kernel-extra-patches/sys_modules_dtb_rockchip_Makefile.patch > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git apply sys/dev/drm/pbp-kernel-extra-patches/mmc.c.patch > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # git rev-parse --verify --short HEAD > > ece746877783 > > root@vm:/ds/src/freebsd/current/14.0/f72926eab00c.generic_drm # cd .. > > root@vm:/ds/src/freebsd/current/14.0 # mv f72926eab00c.generic_drm ece746877783.generic_drm > > > > and then build GENERIC-DRM kernel and boot image on > > 14.0-CURRENT VM : > > > > # cd /usr/src > > # make buildworld TARGET=arm64 > > # make buildkernel TARGET=arm64 KERNCONF=GENERIC-DRM > > # cd /usr/src/release > > # make clean memstick.img TARGET=arm64 TARGET_ARCH=aarch64 KERNCONF=GENERIC-DRM > > > > Then boot from it. Failed : > > > > ---<>--- > > GDB: debug ports: uart > > GDB: current port: uart > > KDB: debugger backends: ddb gdb > > KDB: current backend: ddb > > WARNING: Cannot find freebsd,dts-version property, cannot check DTB compliance > > Copyright (c) 1992-2022 The FreeBSD Project. > > Copyright (c) 1979, 1980, 1983, 1986, 1988, 1989, 1991, 1992, 1993, 1994 > > The Regents of the University of California. All rights reserved. > > FreeBSD is a registered trademark of The FreeBSD Foundation. > > FreeBSD 14.0-CURRENT #0 n252589-ece746877783-dirty: Tue Jan 25 03:42:31 JST 2022 > > root@tbedfc:/usr/obj/usr/src/arm64.aarch64/sys/GENERIC-DRM arm64 > > FreeBSD clang version 13.0.0 (git@github.com:llvm/llvm-project.git llvmorg-13.0.0-0-gd7b669b3a303) > > VT(efifb): resolution 1920x1080 > > module firmware already present! > > real memory = 4150083584 (3957 MB) > > avail memory = 4022452224 (3836 MB) > > Starting CPU 1 (1) > > Starting CPU 2 (2) > > Starting CPU 3 (3) > > Starting CPU 4 (100) > > Starting CPU 5 (101) > > FreeBSD/SMP: Multiprocessor System Detected: 6 CPUs > > arc4random: WARNING: initial seeding bypassed the cryptographic random device because it was not yet seeded and the knob 'bypass_before_seeding' was enabled. > > random: entropy device external interface > > MAP f3f10000 mode 2 pages 4 > > MAP f3f15000 mode 2 pages 4 > > MAP f6f30000 mode 2 pages 16 > > kbd0 at kbdmux0 > > ofwbus0: > > clk_fixed0: on ofwbus0 > > simplebus0: on ofwbus0 > > rk_grf0: mem 0xff320000-0xff320fff on ofwbus0 > > rk3399_pmucru0: mem 0xff750000-0xff750fff on ofwbus0 > > rk3399_cru0: mem 0xff760000-0xff760fff on ofwbus0 > > rk_grf1: mem 0xff770000-0xff77ffff on ofwbus0 > > regfix0: on ofwbus0 > > regfix1: on ofwbus0 > > regfix2: on ofwbus0 > > regfix3: on ofwbus0 > > regfix4: on ofwbus0 > > regfix5: on ofwbus0 > > regfix6: on ofwbus0 > > regfix7: on ofwbus0 > > regfix8: on ofwbus0 > > regfix9: on ofwbus0 > > regfix10: on ofwbus0 > > regfix11: on ofwbus0 > > simple_mfd0: mem 0xff310000-0xff310fff on ofwbus0 > > psci0: on ofwbus0 > > rk_drm0: on ofwbus0 > > gic0: mem 0xfee00000-0xfee0ffff,0xfef00000-0xfefbffff,0xfff00000-0xfff0ffff,0xfff10000-0xfff1ffff,0xfff20000-0xfff2ffff irq 18 on ofwbus0 > > its0: mem 0xfee20000-0xfee3ffff on gic0 > > rk_iodomain0: mem 0-0xff31ffff,0-0xfff on rk_grf0 > > rk_iodomain1: mem 0-0xff76ffff,0-0xffff on rk_grf1 > > rk_pinctrl0: on ofwbus0 > > gpio0: mem 0xff720000-0xff7200ff irq 71 on rk_pinctrl0 > > gpiobus0: on gpio0 > > gpio1: mem 0xff730000-0xff7300ff irq 72 on rk_pinctrl0 > > gpiobus1: on gpio1 > > gpio2: mem 0xff780000-0xff7800ff irq 73 on rk_pinctrl0 > > gpiobus2: on gpio2 > > gpio3: mem 0xff788000-0xff7880ff irq 74 on rk_pinctrl0 > > gpiobus3: on gpio3 > > gpio4: mem 0xff790000-0xff7900ff irq 75 on rk_pinctrl0 > > gpiobus4: on gpio4 > > rk_i2c0: mem 0xff110000-0xff110fff irq 20 on ofwbus0 > > iicbus0: on rk_i2c0 > > rk_i2c1: mem 0xff130000-0xff130fff irq 22 on ofwbus0 > > iicbus1: on rk_i2c1 > > rk_i2c2: mem 0xff3c0000-0xff3c0fff irq 38 on ofwbus0 > > iicbus2: on rk_i2c2 > > fan53555_pmic0: at addr 0x80 on iicbus2 > > fan53555_pmic1: at addr 0x82 on iicbus2 > > rk_i2c3: mem 0xff3d0000-0xff3d0fff irq 39 on ofwbus0 > > iicbus3: on rk_i2c3 > > rk808_pmu0: at addr 0x36 irq 76 on iicbus2 > > rk_vop0: mem 0xff8f0000-0xff8f3efb irq 53 on ofwbus0 > > rk_vop0: VOP version: 3068896 > > generic_timer0: irq 2,3,4,5 on ofwbus0 > > Timecounter "ARM MPCore Timecounter" frequency 24000000 Hz quality 1000 > > Event timer "ARM MPCore Eventtimer" frequency 24000000 Hz quality 1000 > > rk_tsadc0: mem 0xff260000-0xff2600ff irq 35 on ofwbus0 > > mmc_pwrseq0: on ofwbus0 > > rk_edp0: mem 0xff970000-0xff977fff irq 62 on ofwbus0 > > rk_usb2phy0: mem 0-0xff76ffff,0-0xffff on rk_grf1 > > rk_usb2phy1: mem 0-0xff76ffff,0-0xffff on rk_grf1 > > rk_emmcphy0: mem 0-0xff76ffff,0-0xffff on rk_grf1 > > rk_pcie_phy0: mem 0-0xff76ffff,0-0xffff on rk_grf1 > > rk_typec_phy0: mem 0xff7c0000-0xff7fffff on ofwbus0 > > rk_typec_phy1: mem 0xff800000-0xff83ffff on ofwbus0 > > cpulist0: on ofwbus0 > > cpu0: on cpulist0 > > cpufreq_dt0: on cpu0 > > cpufreq_dt0: Found cpu-supply > > cpu1: on cpulist0 > > cpufreq_dt1: on cpu1 > > cpufreq_dt1: Found cpu-supply > > cpu2: on cpulist0 > > cpufreq_dt2: on cpu2 > > cpufreq_dt2: Found cpu-supply > > cpu3: on cpulist0 > > cpufreq_dt3: on cpu3 > > cpufreq_dt3: Found cpu-supply > > cpu4: on cpulist0 > > cpufreq_dt4: on cpu4 > > cpufreq_dt4: Found cpu-supply > > cpu5: on cpulist0 > > cpufreq_dt5: on cpu5 > > cpufreq_dt5: Found cpu-supply > > pmu0: irq 0 on ofwbus0 > > pmu1: irq 1 on ofwbus0 > > pcib0: mem 0xf8000000-0xf9ffffff,0xfd000000-0xfdffffff irq 6,7,8 on ofwbus0 > > pcib0: Gen1 link training timeouted: 0x00080001. > > pci0: on pcib0 > > pcib1: at device 0.0 on pci0 > > pcib0: failed to reserve resource for pcib1 > > pcib1: failed to allocate initial memory window: 0-0xfffff > > pci1: on pcib1 > > rockchip_dwmmc0: mem 0xfe310000-0xfe313fff irq 10 on ofwbus0 > > rockchip_dwmmc0: Hardware version ID is 270a > > rockchip_dwmmc1: mem 0xfe320000-0xfe323fff irq 11 on ofwbus0 > > rockchip_dwmmc1: Hardware version ID is 270a > > mmc0: on rockchip_dwmmc1 > > sdhci_fdt0: mem 0xfe330000-0xfe33ffff irq 12 on ofwbus0 > > rk_emmcphy0: got emmcclk clock > > sdhci_fdt0-slot0: Hardware doesn't specify timeout clock frequency, setting BROKEN_TIMEOUT quirk. > > sdhci_fdt0: 1 slot(s) allocated > > mmc1: on sdhci_fdt0 > > ehci0: mem 0xfe380000-0xfe39ffff irq 13 on ofwbus0 > > usbus0: EHCI version 1.0 > > usbus0 on ehci0 > > ohci0: mem 0xfe3a0000-0xfe3bffff irq 14 on ofwbus0 > > usbus1 on ohci0 > > ehci1: mem 0xfe3c0000-0xfe3dffff irq 15 on ofwbus0 > > usbus2: EHCI version 1.0 > > usbus2 on ehci1 > > ohci1: mem 0xfe3e0000-0xfe3fffff irq 16 on ofwbus0 > > usbus3 on ohci1 > > rk_dwc30: on ofwbus0 > > xhci0: mem 0xfe800000-0xfe8fffff irq 77 on rk_dwc30 > > xhci0: 64 bytes context size, 32-bit DMA > > usbus4: trying to attach > > usbus4 on xhci0 > > rk_dwc31: on ofwbus0 > > xhci1: mem 0xfe900000-0xfe9fffff irq 78 on rk_dwc31 > > xhci1: 64 bytes context size, 32-bit DMA > > usbus5: trying to attach > > usbus5 on xhci1 > > es8316codec0: at addr 0x22 on iicbus0 > > iic0: on iicbus0 > > iic1: on iicbus1 > > uart0: mem 0xff180000-0xff1800ff irq 26 on ofwbus0 > > uart0: debug port (-1,n,8,1) > > uart1: <16750 or compatible> mem 0xff1a0000-0xff1a00ff irq 28 on ofwbus0 > > uart1: console (1500000,n,8,1) > > spi0: mem 0xff1d0000-0xff1d0fff irq 31 on ofwbus0 > > spibus0: on spi0 > > spibus0: at cs 0 mode 0 > > iic2: on iicbus2 > > iicbus3: at addr 0x44 > > iic3: on iicbus3 > > pwm0: mem 0xff420000-0xff42000f on ofwbus0 > > pwmbus0: on pwm0 > > pwmc0: channel 0 on pwmbus0 > > pwm1: mem 0xff420020-0xff42002f on ofwbus0 > > pwmbus1: on pwm1 > > pwmc1: channel 0 on pwmbus1 > > i2s0: mem 0xff890000-0xff890fff irq 51 on ofwbus0 > > Cannot set frequency for clk: clkin_i2s, error: 34 > > Cannot set frequency for clk: xin24m, error: 34 > > pcm0: on ofwbus0 > > gpioc0: on gpio0 > > gpioc1: on gpio1 > > gpioc2: on gpio2 > > gpioc3: on gpio3 > > gpioc4: on gpio4 > > rk_edp_panel0: on ofwbus0 > > gpioled0: on ofwbus0 > > pcm1: on ofwbus0 > > simpleamp0: on ofwbus0 > > armv8crypto0: > > Timecounters tick every 1.000 msec > > usbus0: 480Mbps High Speed USB v2.0 > > usbus1: 12Mbps Full Speed USB v1.0 > > usbus2: 480Mbps High Speed USB v2.0 > > usbus3: 12Mbps Full Speed USB v1.0 > > usbus4: 5.0Gbps Super Speed USB v3.0 > > usbus5: 5.0Gbps Super Speed USB v3.0 > > rk_drm0: port found > > <6>[drm] Connector eDP-1: get mode from tunables: > > <6>[drm] - kern.vt.fb.modes.eDP-1 > > <6>[drm] - kern.vt.fb.default_mode > > rk_drm0: Cannot find port with phandle 10 > > rk_drm_fb_preinit > > <6>[drm] Supports vblank timestamp caching Rev 2 (21.10.2013). > > <6>[drm] No driver support for vblank timestamp query. > > WARNING: Device "fb" is Giant locked and may be deleted before FreeBSD 14.0. > > VT: Replacing driver "efifb" with new "fb". > > <6>[drm] Initialized rockchip 1.0.0 20201113 for rk_drm on minor 0 > > rk808_pmu0: registered as a time-of-day clock, resolution 1.000000s > > ugen3.1: at usbus3 > > uhub0 on usbus3 > > uhub0: on usbus3 > > ugen2.1: at usbus2 > > uhub1 on usbus2 > > uhub1: on usbus2 > > ugen1.1: at usbus1 > > uhub2 on usbus1 > > uhub2: on usbus1 > > ugen5.1: at usbus5 > > uhub3 on usbus5 > > uhub3: on usbus5 > > ugen4.1: at usbus4 > > uhub4 on usbus4 > > uhub4: on usbus4 > > ugen0.1: at usbus0 > > uhub5 on usbus0 > > uhub5: on usbus0 > > mmcsd0: 8GB at mmc0 20.0MHz/4bit/1016-block > > WARNING cur_vblank != vblank->last failed at /usr/src/sys/dev/drm/core/drm_vblank.c:279 > > Fatal data abort: > > x0: ffffa0000091f498 > > x1: 0 > > x2: a8 > > x3: 102 > > x4: 102 > > x5: ffff00009a845990GEOM: mmcsd0: the secondary GPT header is not in the last LBA. > > (_end + 9976a990) > > x6: 0 > > x7: 501 > > x8: ffffa00000d5f000 > > x9: 2 > > x10: 2 > > x11: 0 > > x12: 0 > > x13: 0 > > x14: 0 > > x15: 10 > > x16: 400 > > x17: 0 > > x18: ffff00009a845810 (_end + 9976a810) > > x19: ffffa00000d5b600 > > x20: ffffa0000091f498 > > x21: 102 > > x22: 2 > > x23: ffff000000f10b30 (proc0 + 0) > > x24: ffff000000cb5000 (sdta_vfs_vop_vop_spare1_return0 + 0) > > x25: ffff000000cb5000 (sdta_vfs_vop_vop_spare1_return0 + 0) > > x26: ffff000000cb5000 (sdta_vfs_vop_vop_spare1_return0 + 0) > > x27: ffff000000cb5000 (sdta_vfs_vop_vop_spare1_return0 + 0) > > x28: 0 > > x29: ffff00009a845810 (_end + 9976a810) > > sp: ffff00009a845810 > > lr: ffff0000007080e8 (linux_alloc_current + 58) > > elr: ffff000000708360 (linux_alloc_current + 2d0) > > spsr: 60000045 > > far: e > > esr: 96000004 > > WARNING !list_empty(&lock->head) failed at /usr/src/sys/dev/drm/core/drm_modeset_lock.c:268 > > WARNING !list_empty(&lock->head) failed at /usr/src/sys/dev/drm/core/drm_modeset_lock.c:268 > > WARNING !list_empty(&lock->head) failed at /usr/src/sys/dev/drm/core/drm_modeset_lock.c:268 > > WARNING !list_empty(&lock->head) failed at /usr/src/sys/dev/drm/core/drm_modeset_lock.c:268 > > WARNING !list_empty(&lock->head) failed at /usr/src/sys/dev/drm/core/drm_modeset_lock.c:268 > > WARNING !drm_modeset_is_locked(&crtc->mutex) failed at /usr/src/sys/dev/drm/core/drm_atomic_helper.c:615 > > WARNING !drm_modeset_is_locked(&dev->mode_config.connection_mutex) failed at /usr/src/sys/dev/drm/core/drm_atomic_helper.c:660 > > WARNING !drm_modeset_is_locked(&plane->mutex) failed at /usr/src/sys/dev/drm/core/drm_atomic_helper.c:865 > > WARNING !drm_modeset_is_locked(&plane->mutex) failed at /usr/src/sys/dev/drm/core/drm_atomic_helper.c:865 > > <3>[drm: 0xffff00000090f048] *ERROR* [CRTC:33:crtc-0] hw_done timed out > > <3>[drm: 0xffff00000090f074] *ERROR* [CRTC:33:crtc-0] flip_done timed out > > <3>[drm: 0xffff00000090f0fc] *ERROR* [CONNECTOR:35:eDP-1] hw_done timed out > > <3>[drm: 0xffff00000090f128] *ERROR* [CONNECTOR:35:eDP-1] flip_done timed out > > <3>[drm: 0xffff00000090f1b8] *ERROR* [PLANE:31:plane-0] hw_done timed out > > <3>[drm: 0xffff00000090f1e4] *ERROR* [PLANE:31:plane-0] flip_done timed out > > <3>[drm: 0xffff00000090f1b8] *ERROR* [PLANE:32:plane-1] hw_done timed out > > <3>[drm: 0xffff00000090f1e4] *ERROR* [PLANE:32:plane-1] flip_done timed out > > [CRTC:33:crtc-0] vblank wait timed out > > > > Is there any suggetions ? > > > I am currently building a newer image to try to reproduce, in the mean I put my image to [1]. [1] http://www.truefc.org/~kiri/freebsd/pbp/FreeBSD-14.0-CURRENT-GENERIC-DRM-PINEBOOKPRO-20220125-ece746877783-271989-memstick.img > time did you try my prebuild image here > http://build.schmitz.computer/build/pbp/FreeBSD-14.0-CURRENT-arm64-aarch64-PINEBOOKPRO.img.xz > ? > > Thanks > /jsm > > > Best regards > > > > [1] https://github.com/jsm222/drm-subtree > > --- > > Kazuhiko Kiriyama Regards --- Kazuhiko Kiriyama