1/* SPDX-License-Identifier: MIT */ 2#ifndef __NVKM_EVENT_H__ 3#define __NVKM_EVENT_H__ 4#include <core/os.h> 5struct nvkm_object; 6struct nvkm_oclass; 7struct nvkm_uevent; 8 9struct nvkm_event { 10 const struct nvkm_event_func *func; 11 struct nvkm_subdev *subdev; 12 13 int types_nr; 14 int index_nr; 15 16 spinlock_t refs_lock; 17 rwlock_t list_lock; 18 int *refs; 19 20 struct list_head ntfy; 21}; 22 23struct nvkm_event_func { 24 void (*init)(struct nvkm_event *, int type, int index); 25 void (*fini)(struct nvkm_event *, int type, int index); 26}; 27 28int __nvkm_event_init(const struct nvkm_event_func *func, struct nvkm_subdev *, int types_nr, 29 int index_nr, struct nvkm_event *); 30 31/* Each nvkm_event needs its own lockdep class due to inter-dependencies, to 32 * prevent lockdep false-positives. 33 * 34 * Inlining the spinlock initialisation ensures each is unique. 35 */ 36static __always_inline int 37nvkm_event_init(const struct nvkm_event_func *func, struct nvkm_subdev *subdev, 38 int types_nr, int index_nr, struct nvkm_event *event) 39{ 40 spin_lock_init(&event->refs_lock); 41 rwlock_init(&event->list_lock); 42 return __nvkm_event_init(func, subdev, types_nr, index_nr, event); 43} 44 45void nvkm_event_fini(struct nvkm_event *); 46 47#define NVKM_EVENT_KEEP 0 48#define NVKM_EVENT_DROP 1 49struct nvkm_event_ntfy; 50typedef int (*nvkm_event_func)(struct nvkm_event_ntfy *, u32 bits); 51 52struct nvkm_event_ntfy { 53 struct nvkm_event *event; 54 int id; 55 u32 bits; 56 bool wait; 57 nvkm_event_func func; 58 59 atomic_t allowed; 60 bool running; 61 62 struct list_head head; 63}; 64 65void nvkm_event_ntfy(struct nvkm_event *, int id, u32 bits); 66bool nvkm_event_ntfy_valid(struct nvkm_event *, int id, u32 bits); 67void nvkm_event_ntfy_add(struct nvkm_event *, int id, u32 bits, bool wait, nvkm_event_func, 68 struct nvkm_event_ntfy *); 69void nvkm_event_ntfy_del(struct nvkm_event_ntfy *); 70void nvkm_event_ntfy_allow(struct nvkm_event_ntfy *); 71void nvkm_event_ntfy_block(struct nvkm_event_ntfy *); 72 73typedef int (*nvkm_uevent_func)(struct nvkm_object *, u64 token, u32 bits); 74 75int nvkm_uevent_new(const struct nvkm_oclass *, void *argv, u32 argc, struct nvkm_object **); 76int nvkm_uevent_add(struct nvkm_uevent *, struct nvkm_event *, int id, u32 bits, nvkm_uevent_func); 77#endif 78