Files
mop3/kernel/irq/irq.c
kamkow1 927d9e4c73
All checks were successful
Build documentation / build-and-deploy (push) Successful in 2m19s
Working PS/2 keyboard driver
2026-02-15 14:28:07 +01:00

52 lines
1.1 KiB
C

#include <irq/irq.h>
#include <libk/rbtree.h>
#include <libk/std.h>
#include <mm/liballoc.h>
#include <sync/spin_lock.h>
#include <sys/debug.h>
#if defined(__x86_64__)
#include <amd64/apic.h>
#include <amd64/intr.h>
#endif
static struct rb_node_link* irq_tree = NULL;
static spin_lock_t irqs_lock = SPIN_LOCK_INIT;
bool irq_attach (void (*func) (void*, void*), void* arg, uint32_t irq_num) {
struct irq* irq = malloc (sizeof (*irq));
if (irq == NULL) {
return false;
}
irq->func = func;
irq->arg = arg;
irq->irq_num = irq_num;
spin_lock (&irqs_lock);
rbtree_insert (struct irq, &irq_tree, &irq->irq_tree_link, irq_tree_link, irq_num);
spin_unlock (&irqs_lock);
return true;
}
void irq_detach (uint32_t irq_num) {
struct irq* irq = irq_find (irq_num);
spin_lock (&irqs_lock);
rbtree_delete (&irq_tree, &irq->irq_tree_link);
spin_unlock (&irqs_lock);
free (irq);
}
struct irq* irq_find (uint32_t irq_num) {
struct irq* irq = NULL;
spin_lock (&irqs_lock);
rbtree_find (struct irq, &irq_tree, irq_num, irq, irq_tree_link, irq_num);
spin_unlock (&irqs_lock);
return irq;
}