X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=doc%2Fuserprog.texi;h=0746b2e68f791af7545793a3458bd5d6ed4851a3;hb=96d95e6605de12945100bba503031ad8d56d470a;hp=25b7a70b7c6679bae217742b8e5203060b29abf3;hpb=817894669e548f9141a2f9680626772c0e5455a6;p=pintos-anon diff --git a/doc/userprog.texi b/doc/userprog.texi index 25b7a70..0746b2e 100644 --- a/doc/userprog.texi +++ b/doc/userprog.texi @@ -247,14 +247,21 @@ requirements: @itemize @bullet @item -The kernel should print out the program's name and exit status -whenever a process terminates, e.g.@: @code{shell: exit(-1)}, whether -termination is due to a call to the @code{exit} system call or for -another reason. The name printed should be the full name passed to -@func{process_execute}, except that it is acceptable to truncate it to -15 characters to allow for the limited space in @struct{thread}. +The kernel should print out the program's name and exit status whenever +a process terminates, whether termination is caused by the @code{exit} +system call or for another reason. @itemize @minus +@item +The message must be formatted exactly as if it was printed with +@code{printf ("%s: exit(%d)\n", @dots{});} given appropriate arguments. + +@item +The name printed should be the full name passed to +@func{process_execute}, except that it is acceptable to truncate it to +15 characters to allow for the limited space in @struct{thread}. The +name printed need not include arguments. + @item Do not print a message when a kernel thread that is not a process terminates. @@ -264,7 +271,7 @@ Do not print messages about process termination for the @code{halt} system call. @item -No message need be printed when a process that fails to load. +No message need be printed when a process fails to load. @end itemize @item @@ -459,7 +466,7 @@ the @file{filesys} directory, and release it afterward. Don't forget that @func{process_execute} also accesses files. @strong{For now, we recommend against modifying code in the @file{filesys} directory.} -We have provided you a function for each system call in +We have provided you a user-level function for each system call in @file{lib/user/syscall.c}. These provide a way for user processes to invoke each system call from a C program. Each of them calls an assembly language routine in @file{lib/user/syscall-stub.S}, which in @@ -964,3 +971,9 @@ In this example, the caller's stack pointer would be at The 80@var{x}86 convention for function return values is to place them in the @samp{EAX} register. System calls that return a value can do so by modifying the @samp{eax} member of @struct{intr_frame}. + +You should try to avoid writing large amounts of repetitive code for +implementing system calls. Each system call argument, whether an +integer or a pointer, takes up 4 bytes on the stack. You should be able +to take advantage of this to avoid writing much near-identical code for +retrieving each system call's arguments from the stack.