1110e6e02SM Chetan Kumar // SPDX-License-Identifier: GPL-2.0-only
2110e6e02SM Chetan Kumar /*
3110e6e02SM Chetan Kumar  * Copyright (C) 2020-21 Intel Corporation.
4110e6e02SM Chetan Kumar  */
5110e6e02SM Chetan Kumar 
6110e6e02SM Chetan Kumar #include <linux/device.h>
7110e6e02SM Chetan Kumar #include <linux/kobject.h>
8110e6e02SM Chetan Kumar #include <linux/slab.h>
9110e6e02SM Chetan Kumar 
10110e6e02SM Chetan Kumar #include "iosm_ipc_uevent.h"
11110e6e02SM Chetan Kumar 
12110e6e02SM Chetan Kumar /* Update the uevent in work queue context */
ipc_uevent_work(struct work_struct * data)13110e6e02SM Chetan Kumar static void ipc_uevent_work(struct work_struct *data)
14110e6e02SM Chetan Kumar {
15110e6e02SM Chetan Kumar 	struct ipc_uevent_info *info;
16110e6e02SM Chetan Kumar 	char *envp[2] = { NULL, NULL };
17110e6e02SM Chetan Kumar 
18110e6e02SM Chetan Kumar 	info = container_of(data, struct ipc_uevent_info, work);
19110e6e02SM Chetan Kumar 
20110e6e02SM Chetan Kumar 	envp[0] = info->uevent;
21110e6e02SM Chetan Kumar 
22110e6e02SM Chetan Kumar 	if (kobject_uevent_env(&info->dev->kobj, KOBJ_CHANGE, envp))
23110e6e02SM Chetan Kumar 		pr_err("uevent %s failed to sent", info->uevent);
24110e6e02SM Chetan Kumar 
25110e6e02SM Chetan Kumar 	kfree(info);
26110e6e02SM Chetan Kumar }
27110e6e02SM Chetan Kumar 
ipc_uevent_send(struct device * dev,char * uevent)28110e6e02SM Chetan Kumar void ipc_uevent_send(struct device *dev, char *uevent)
29110e6e02SM Chetan Kumar {
30110e6e02SM Chetan Kumar 	struct ipc_uevent_info *info = kzalloc(sizeof(*info), GFP_ATOMIC);
31110e6e02SM Chetan Kumar 
32110e6e02SM Chetan Kumar 	if (!info)
33110e6e02SM Chetan Kumar 		return;
34110e6e02SM Chetan Kumar 
35110e6e02SM Chetan Kumar 	/* Initialize the kernel work queue */
36110e6e02SM Chetan Kumar 	INIT_WORK(&info->work, ipc_uevent_work);
37110e6e02SM Chetan Kumar 
38110e6e02SM Chetan Kumar 	/* Store the device and event information */
39110e6e02SM Chetan Kumar 	info->dev = dev;
40*856a5c97SM Chetan Kumar 	snprintf(info->uevent, MAX_UEVENT_LEN, "IOSM_EVENT=%s", uevent);
41110e6e02SM Chetan Kumar 
42110e6e02SM Chetan Kumar 	/* Schedule uevent in process context using work queue */
43110e6e02SM Chetan Kumar 	schedule_work(&info->work);
44110e6e02SM Chetan Kumar }
45