summaryrefslogtreecommitdiff
path: root/src/kernel/pipe.c
diff options
context:
space:
mode:
authordzwdz2024-07-27 19:59:37 +0200
committerdzwdz2024-07-27 20:00:29 +0200
commitfe6fbfa07aa8326926049cf62560d940bc7305c0 (patch)
treee97060cb23c8a5a227fe615b97d9213d5fc2ad1e /src/kernel/pipe.c
parent58514d351e1f0e8871f534422cf025109ddbb844 (diff)
kernel: don't use pointer types for registers, add proc_savereturn
Diffstat (limited to 'src/kernel/pipe.c')
-rw-r--r--src/kernel/pipe.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/kernel/pipe.c b/src/kernel/pipe.c
index b7f5ad3..5efafc8 100644
--- a/src/kernel/pipe.c
+++ b/src/kernel/pipe.c
@@ -9,7 +9,7 @@ void pipe_joinqueue(Handle *h, Proc *proc, void __user *pbuf, size_t pbuflen) {
assert(h && h->type == HANDLE_PIPE);
assert(h->readable ^ h->writeable);
if (!h->pipe.sister) {
- regs_savereturn(&proc->regs, h->readable ? 0 : -EPIPE);
+ proc_savereturn(proc, h->readable ? 0 : -EPIPE);
return;
}
@@ -54,8 +54,8 @@ static void pipe_trytransfer(Handle *h) {
h->pipe.sister->pipe.queued = h->pipe.sister->pipe.queued->waits4pipe.next;
proc_setstate(rdr, PS_RUNNING);
proc_setstate(wtr, PS_RUNNING);
- regs_savereturn(&rdr->regs, len);
- regs_savereturn(&wtr->regs, len);
+ proc_savereturn(rdr, len);
+ proc_savereturn(wtr, len);
}
void pipe_invalidate_end(Handle *h) {
@@ -63,7 +63,7 @@ void pipe_invalidate_end(Handle *h) {
while (p) {
assert(p->state == PS_WAITS4PIPE);
proc_setstate(p, PS_RUNNING);
- regs_savereturn(&p->regs, -1);
+ proc_savereturn(p, -1);
p = p->waits4pipe.next;
}
h->pipe.queued = NULL;