[PATCH 4/5] staging: vchiq_arm: Create keep-alive thread during probe
Stefan Wahren
wahrenst at gmx.net
Thu Jun 26 13:14:42 PDT 2025
Hi Maíra,
[add Arnd]
Am 26.06.25 um 20:22 schrieb Maíra Canal:
> Hi Stefan,
>
> On 09/03/25 09:50, Stefan Wahren wrote:
>> Creating the keep-alive thread in vchiq_platform_init_state have
>> the following advantages:
>> - abort driver probe if kthread_create fails (more consistent behavior)
>> - make resource release process easier
>>
>> Since vchiq_keepalive_thread_func is defined below
>> vchiq_platform_init_state, the latter must be moved.
>>
>> Signed-off-by: Stefan Wahren <wahrenst at gmx.net>
>> ---
>> .../interface/vchiq_arm/vchiq_arm.c | 69 +++++++++----------
>> 1 file changed, 34 insertions(+), 35 deletions(-)
>>
>
> After this patch landed on 6.12 stable, I started to observe the
> following warning in Mesa CI [1]:
Is this also reproducible with 6.15.x or mainline ?
>
> 20:07:07.830: [ 242.653532] INFO: task vchiq-keep/0:85 blocked for
> more than 120 seconds.
> 20:07:07.835: [ 242.660404] Not tainted 6.12.34-v8-+ #13
> 20:07:07.843: [ 242.666173] "echo 0 >
> /proc/sys/kernel/hung_task_timeout_secs" disables this message.
> 20:07:07.852: [ 242.677126] task:vchiq-keep/0 state:D stack:0
> pid:85 tgid:85 ppid:2 flags:0x00000008
> 20:07:07.854: [ 242.690734] Call trace:
> 20:07:07.857: [ 242.693191] __switch_to+0x188/0x230
> 20:07:07.858: [ 242.697010] __schedule+0xa54/0xb28
> 20:07:07.859: [ 242.704889] schedule+0x80/0x120
> 20:07:07.859: [ 242.712581] schedule_preempt_disabled+0x30/0x50
> 20:07:07.860: [ 242.721437] kthread+0xd4/0x1a0
> 20:07:07.861: [ 242.724606] ret_from_fork+0x10/0x20
>
> If I revert this patch, I no longer get those warnings. From that, I was
> wondering: is it possible that in some scenarios, we might never
> actually get to the connected state and therefore, we wouldn't wake up
> the kthread that we created when we initialized the state?
Sure we communicate to the VideoCore and there might be reasons the
connection fail. I'm not aware that a missing wakeup cause a hanging task.
Best regards
>
> [1] https://gitlab.freedesktop.org/mairacanal/mesa/-/jobs/78940369
>
> Best Regards,
> - Maíra
>
>> diff --git
>> a/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c
>> b/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c
>> index 0c7ea2d0ee85..64f9536f1232 100644
>> --- a/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c
>> +++ b/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c
>> @@ -280,29 +280,6 @@ static int vchiq_platform_init(struct
>> platform_device *pdev, struct vchiq_state
>> return 0;
>> }
>>
>> -int
>> -vchiq_platform_init_state(struct vchiq_state *state)
>> -{
>> - struct vchiq_arm_state *platform_state;
>> -
>> - platform_state = devm_kzalloc(state->dev,
>> sizeof(*platform_state), GFP_KERNEL);
>> - if (!platform_state)
>> - return -ENOMEM;
>> -
>> - rwlock_init(&platform_state->susp_res_lock);
>> -
>> - init_completion(&platform_state->ka_evt);
>> - atomic_set(&platform_state->ka_use_count, 0);
>> - atomic_set(&platform_state->ka_use_ack_count, 0);
>> - atomic_set(&platform_state->ka_release_count, 0);
>> -
>> - platform_state->state = state;
>> -
>> - state->platform_state = (struct opaque_platform_state
>> *)platform_state;
>> -
>> - return 0;
>> -}
>> -
>> static struct vchiq_arm_state *vchiq_platform_get_arm_state(struct
>> vchiq_state *state)
>> {
>> return (struct vchiq_arm_state *)state->platform_state;
>> @@ -1011,6 +988,39 @@ vchiq_keepalive_thread_func(void *v)
>> return 0;
>> }
>>
>> +int
>> +vchiq_platform_init_state(struct vchiq_state *state)
>> +{
>> + struct vchiq_arm_state *platform_state;
>> + char threadname[16];
>> +
>> + platform_state = devm_kzalloc(state->dev,
>> sizeof(*platform_state), GFP_KERNEL);
>> + if (!platform_state)
>> + return -ENOMEM;
>> +
>> + snprintf(threadname, sizeof(threadname), "vchiq-keep/%d",
>> + state->id);
>> + platform_state->ka_thread =
>> kthread_create(&vchiq_keepalive_thread_func,
>> + (void *)state, threadname);
>> + if (IS_ERR(platform_state->ka_thread)) {
>> + dev_err(state->dev, "couldn't create thread %s\n", threadname);
>> + return PTR_ERR(platform_state->ka_thread);
>> + }
>> +
>> + rwlock_init(&platform_state->susp_res_lock);
>> +
>> + init_completion(&platform_state->ka_evt);
>> + atomic_set(&platform_state->ka_use_count, 0);
>> + atomic_set(&platform_state->ka_use_ack_count, 0);
>> + atomic_set(&platform_state->ka_release_count, 0);
>> +
>> + platform_state->state = state;
>> +
>> + state->platform_state = (struct opaque_platform_state
>> *)platform_state;
>> +
>> + return 0;
>> +}
>> +
>> int
>> vchiq_use_internal(struct vchiq_state *state, struct vchiq_service
>> *service,
>> enum USE_TYPE_E use_type)
>> @@ -1331,7 +1341,6 @@ void vchiq_platform_conn_state_changed(struct
>> vchiq_state *state,
>> enum vchiq_connstate newstate)
>> {
>> struct vchiq_arm_state *arm_state =
>> vchiq_platform_get_arm_state(state);
>> - char threadname[16];
>>
>> dev_dbg(state->dev, "suspend: %d: %s->%s\n",
>> state->id, get_conn_state_name(oldstate),
>> get_conn_state_name(newstate));
>> @@ -1346,17 +1355,7 @@ void vchiq_platform_conn_state_changed(struct
>> vchiq_state *state,
>>
>> arm_state->first_connect = 1;
>> write_unlock_bh(&arm_state->susp_res_lock);
>> - snprintf(threadname, sizeof(threadname), "vchiq-keep/%d",
>> - state->id);
>> - arm_state->ka_thread = kthread_create(&vchiq_keepalive_thread_func,
>> - (void *)state,
>> - threadname);
>> - if (IS_ERR(arm_state->ka_thread)) {
>> - dev_err(state->dev, "suspend: Couldn't create thread %s\n",
>> - threadname);
>> - } else {
>> - wake_up_process(arm_state->ka_thread);
>> - }
>> + wake_up_process(arm_state->ka_thread);
>> }
>>
>> static const struct of_device_id vchiq_of_match[] = {
>> --
>> 2.34.1
>>
>>
>
>
More information about the linux-arm-kernel
mailing list