Files
mop3/kernel/device/device.h
kamkow1 e5ebd7f3ba
All checks were successful
Build ISO image / build-and-deploy (push) Successful in 2m21s
Build documentation / build-and-deploy (push) Successful in 54s
Use a big-lock for kernel sychronization instead of fine-grained locking
2026-04-27 18:06:02 +02:00

56 lines
1.9 KiB
C

#ifndef _KERNEL_DEVICE_DEVICE_H
#define _KERNEL_DEVICE_DEVICE_H
#include <device_info.h>
#include <libk/hash.h>
#include <libk/list.h>
#include <libk/std.h>
#include <proc/proc.h>
#include <proc/reschedule.h>
#include <sync/spin_lock.h>
#include <sys/smp.h>
#define DEVICES_MAX 1024
#define device_op1(d, op, proc, rctx, a1, a2, a3, a4, ...) \
(d)->ops[(op)]((d), (proc), (rctx), (void*)(a1), (void*)(a2), (void*)(a3), (void*)(a4))
#define device_op(d, op, proc, rctx, ...) \
device_op1(d, op, proc, rctx, __VA_ARGS__, NULL, NULL, NULL, NULL)
struct device;
typedef int (*device_op_func_t)(struct device* device, struct proc*, struct reschedule_ctx* rctx,
void* a1, void* a2, void* a3, void* a4);
typedef bool (*device_init_func_t)(struct device* device, void* arg, struct proc* proc,
struct reschedule_ctx* rctx);
typedef void (*device_fini_func_t)(struct device* device, struct proc* proc,
struct reschedule_ctx* rctx);
struct device {
char key[0x100];
device_op_func_t ops[32];
struct hash_node_link device_table_link;
struct list_node_link subdevices_link;
device_init_func_t init;
device_fini_func_t fini;
void* udata;
int type;
struct list_node_link* subdevices;
};
struct device* device_create(int type, const char* key, device_op_func_t* ops, size_t ops_len,
device_init_func_t init, device_fini_func_t fini, void* arg,
struct proc* proc, struct reschedule_ctx* rctx);
void device_delete(const char* key, struct proc* proc, struct reschedule_ctx* rctx);
struct device* device_find(const char* key);
size_t device_populate_device_infos(struct device_info* infos, size_t count);
void devices_init(void);
#endif // _KERNEL_DEVICE_DEVICE_H