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 /user/trace.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 'user/trace.c')
-rw-r--r-- | user/trace.c | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/user/trace.c b/user/trace.c new file mode 100644 index 0000000..dd77760 --- /dev/null +++ b/user/trace.c @@ -0,0 +1,27 @@ +#include "kernel/param.h" +#include "kernel/types.h" +#include "kernel/stat.h" +#include "user/user.h" + +int +main(int argc, char *argv[]) +{ + int i; + char *nargv[MAXARG]; + + if(argc < 3 || (argv[1][0] < '0' || argv[1][0] > '9')){ + fprintf(2, "Usage: %s mask command\n", argv[0]); + exit(1); + } + + if (trace(atoi(argv[1])) < 0) { + fprintf(2, "%s: trace failed\n", argv[0]); + exit(1); + } + + for(i = 2; i < argc && i < MAXARG; i++){ + nargv[i-2] = argv[i]; + } + exec(nargv[0], nargv); + exit(0); +} |