summaryrefslogtreecommitdiff
path: root/src/kernel/vfs/procfs.c
diff options
context:
space:
mode:
authordzwdz2023-09-25 00:25:53 +0200
committerdzwdz2023-09-25 00:25:53 +0200
commit75f137b85a36338eafd27bf290910b102467ba5b (patch)
treed627462cce3c63ae5e67e09388d25bd65647a9b4 /src/kernel/vfs/procfs.c
parent681470cf98a6e512627e67620b39c090b9e98aba (diff)
kernel/procfs: `intrdown` node for sending an interrupt to all children
Diffstat (limited to 'src/kernel/vfs/procfs.c')
-rw-r--r--src/kernel/vfs/procfs.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/kernel/vfs/procfs.c b/src/kernel/vfs/procfs.c
index 5031840..2e3130d 100644
--- a/src/kernel/vfs/procfs.c
+++ b/src/kernel/vfs/procfs.c
@@ -11,6 +11,7 @@ enum phandle_type {
PhRoot,
PhDir,
PhIntr,
+ PhIntrDown,
PhMem,
};
@@ -55,6 +56,8 @@ openpath(const char *path, size_t len, Proc *root)
type = PhDir;
} else if (len == 4 && memcmp(path, "intr", 4) == 0) {
type = PhIntr;
+ } else if (len == 8 && memcmp(path, "intrdown", 8) == 0) {
+ type = PhIntrDown;
} else if (len == 3 && memcmp(path, "mem", 3) == 0) {
type = PhMem;
} else {
@@ -145,10 +148,18 @@ procfs_accept(VfsReq *req)
req->output.len
);
vfsreq_finish_short(req, res);
- } else if (req->type == VFSOP_WRITE && h->type == PhIntr) {
+ } else if (req->type == VFSOP_WRITE &&
+ (h->type == PhIntr || h->type == PhIntrDown))
+ {
size_t len = min(sizeof buf, req->input.len);
len = pcpy_from(req->caller, buf, req->input.buf, len);
- proc_intr(p, buf, len);
+ if (h->type == PhIntr) {
+ proc_intr(p, buf, len);
+ } else {
+ for (Proc *it = p->child; it; it = proc_next(it, p)) {
+ proc_intr(it, buf, len);
+ }
+ }
vfsreq_finish_short(req, req->input.len);
} else {
vfsreq_finish_short(req, -ENOSYS);