Re: [PATCH v2] drm/loongson: stop to set get_vblank_timestamp for LS7A1000 CRTC
From: Thomas Zimmermann
Date: Mon Mar 23 2026 - 06:32:04 EST
Hi
Am 23.03.26 um 10:40 schrieb Icenowy Zheng:
在 2026-03-23一的 11:40 +0800,Jianmin Lv写道:
The warning information is copied here:
On 2026/3/21 下午5:29, Icenowy Zheng wrote:
在 2026-03-21六的 17:28 +0800,Icenowy Zheng写道:The drm_crtc_vblank_helper_get_vblank_timestamp will call
As there's no known hardware capability about querying vblank on
the
LS7A1000 display controller, setting get_vblank_timestamp will
mislead the
kernel about the support of DC-backed high precision vblank
query.
Drop this function pointer in the CRTC function table for
LS7A1000.
This solves a kernel warning when booting Linux 7.0-rc3 on a
Loongson-3A4000+LS7A1000 Haier Boyue G51 laptop (with injected
EDID
for
replicating the display timing set by the firmware).
get_scanout_position hook to caculate timestamp, and the driver has
get_scanout_position to support it (LS7A1000 has related register).
So
the get_vblank_timestamp hook is ok for LS7A1000, and we'd better
look
into the warning information.
```
[ 0.334960] ------------[ cut here ]------------
[ 0.334960] WARNING: drivers/gpu/drm/drm_vblank.c:747 at
drm_crtc_vblank_helper_get_vblank_timestamp_internal+0x3c8/0x438,
CPU#0: kworker/0:1/11
[ 0.334960] loongson 0000:00:06.1: [drm]
drm_WARN_ON_ONCE(drm_drv_uses_atomic_modeset(dev))
This is what you should investigate. mode->crtc_clock seems invalid. [1]
[1] https://elixir.bootlin.com/linux/v6.19.9/source/drivers/gpu/drm/drm_vblank.c#L743
Best regards
Thomas
[ 0.334960] Modules linked in:
[ 0.334960] CPU: 0 UID: 0 PID: 11 Comm: kworker/0:1 Not tainted
7.0.0-rc4-3a4000-laptop-test+ #31 PREEMPT
[ 0.334960] Hardware name: Haier Boyue G51/Boyue G51, BIOS
K3L3A4000.HR10.200909.T 09/09/2020
[ 0.334960] Workqueue: events drm_fb_helper_damage_work
[ 0.334960] Stack : ffffffff819dec03 0000000000000000
0000000000000018 9800000100223938
[ 0.334960] 9800000100223938 9800000100223a68
0000000000000000 0000000000000000
[ 0.334960] b8e8b3f2ec6b8200 98000000092bffa8
9800000100223768 0000000000000000
[ 0.334960] ffffffff81632b08 0000000000000030
ffffffff813c9530 0000000000200b20
[ 0.334960] fffffffffffffffc 0000000000000000
0000000000000000 ffffffff816c1d50
[ 0.334960] ffffffff81890000 00000000000002eb
0000000000000000 ffffffff80c1b180
[ 0.334960] 9800000100ff8500 0000000000000000
9800000005c965a8 0000000000000000
[ 0.334960] ffffffff81a70000 9800000100220000
9800000100223930 0000000000000000
[ 0.334960] ffffffff802274dc 0000000000000000
0000000000000000 0000000000000000
[ 0.334960] 0000000000000000 0000000000000000
ffffffff802274fc b8e8b3f2ec6b8200
[ 0.334960] ...
[ 0.334960] Call Trace:
[ 0.334960] [<ffffffff802274fc>] show_stack+0x64/0x158
[ 0.334960] [<ffffffff8021bac4>] dump_stack_lvl+0x70/0xb0
[ 0.334960] [<ffffffff8026a988>] __warn+0xa8/0x120
[ 0.334960] [<ffffffff8026ab60>] warn_slowpath_fmt+0x160/0x1f8
[ 0.334960] [<ffffffff80be5668>]
drm_crtc_vblank_helper_get_vblank_timestamp_internal+0x3c8/0x438
[ 0.334960] [<ffffffff80be48d8>]
drm_crtc_get_last_vbltimestamp+0x68/0xb0
[ 0.334960] [<ffffffff80be5e14>] drm_update_vblank_count+0xac/0x418
[ 0.334960] [<ffffffff80be6270>] drm_vblank_enable+0xf0/0x288
[ 0.334960] [<ffffffff80be7010>] drm_vblank_get+0xf8/0x160
[ 0.334960] [<ffffffff80beb2e0>]
drm_client_modeset_wait_for_vblank+0x50/0xa0
[ 0.334960] [<ffffffff80c0a144>]
drm_fb_helper_damage_work+0x8c/0x1d8
[ 0.334960] [<ffffffff8028fac8>] process_one_work+0x198/0x348
[ 0.334960] [<ffffffff802906c0>] worker_thread+0x238/0x390
[ 0.334960] [<ffffffff8029c0d8>] kthread+0x160/0x198
[ 0.334960] [<ffffffff8021fd8c>] ret_from_kernel_thread+0x14/0x1c
[ 0.334960] ---[ end trace 0000000000000000 ]---
```
Signed-off-by: Icenowy Zheng <zhengxingda@xxxxxxxxxxx>Oh forgot to attach when crafting v2:
```
Acked-by: Thomas Zimmermann <tzimmermann@xxxxxxx>
```
---
Changes in v2:
- Re-formatted Loongson product model numbers per request from
Huacai.
drivers/gpu/drm/loongson/lsdc_crtc.c | 1 -
1 file changed, 1 deletion(-)
diff --git a/drivers/gpu/drm/loongson/lsdc_crtc.c
b/drivers/gpu/drm/loongson/lsdc_crtc.c
index 587fbe285e9ef..b3af8e0cdb15f 100644
--- a/drivers/gpu/drm/loongson/lsdc_crtc.c
+++ b/drivers/gpu/drm/loongson/lsdc_crtc.c
@@ -721,7 +721,6 @@ static const struct drm_crtc_funcs
ls7a1000_crtc_funcs = {
.late_register = lsdc_crtc_late_register,
.enable_vblank = lsdc_crtc_enable_vblank,
.disable_vblank = lsdc_crtc_disable_vblank,
- .get_vblank_timestamp =
drm_crtc_vblank_helper_get_vblank_timestamp,
.atomic_print_state = lsdc_crtc_atomic_print_state,
};
--
--
Thomas Zimmermann
Graphics Driver Developer
SUSE Software Solutions Germany GmbH
Frankenstr. 146, 90461 Nürnberg, Germany, www.suse.com
GF: Jochen Jaser, Andrew McDonald, Werner Knoblich, (HRB 36809, AG Nürnberg)