diff options
author | Mole Shang <[email protected]> | 2024-01-18 17:35:27 +0800 |
---|---|---|
committer | Mole Shang <[email protected]> | 2024-02-05 18:10:56 +0800 |
commit | 283d5ab4c964ab525e45fcade06d6fd7e977c43e (patch) | |
tree | bc44a1e2c447fb965cf5d5c2cfdcfa71658dbbbf /kernel/proc.c | |
parent | 0d6a64fa06ce6aae729fa05a539eadd88fa59007 (diff) | |
download | xv6-labs-283d5ab4c964ab525e45fcade06d6fd7e977c43e.tar.gz xv6-labs-283d5ab4c964ab525e45fcade06d6fd7e977c43e.tar.bz2 xv6-labs-283d5ab4c964ab525e45fcade06d6fd7e977c43e.zip |
lab syscall: finish
Conflicts:
kernel/syscall.c
kernel/syscall.h
user/user.h
user/usys.pl
Diffstat (limited to 'kernel/proc.c')
-rw-r--r-- | kernel/proc.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/kernel/proc.c b/kernel/proc.c index 58a8a0b..5aa616f 100644 --- a/kernel/proc.c +++ b/kernel/proc.c @@ -299,6 +299,9 @@ fork(void) // copy saved user registers. *(np->trapframe) = *(p->trapframe); + // inherit trace_mask + np->trace_mask = p->trace_mask; + // Cause fork to return 0 in the child. np->trapframe->a0 = 0; @@ -686,3 +689,20 @@ procdump(void) printf("\n"); } } + +int +get_nproc(void) +{ + int n = 0; + struct proc *p; + + for(int i = 0; i < NPROC; i++) { + p = &proc[i]; + acquire(&p->lock); + if(p->state != UNUSED) + n++; + release(&p->lock); + } + + return n; +} |