diff --git a/exec.c b/exec.c index a6de18f..0a9ca59 100644 --- a/exec.c +++ b/exec.c @@ -48,9 +48,6 @@ exec(char *path, char **argv) } iunlockput(ip); - // XXX rtm: what about the BSS? shouldn't there be some - // bzero()ing here? - // Allocate and initialize stack at sz sz = spbottom = PGROUNDUP(sz); if(!(sz = allocuvm(pgdir, sz, sz + PGSIZE))) diff --git a/usertests.c b/usertests.c index 77495bf..e62703d 100644 --- a/usertests.c +++ b/usertests.c @@ -1419,6 +1419,21 @@ validatetest(void) printf(stdout, "validate ok\n"); } +char uninit[10000]; +void +bsstest(void) +{ + int i; + printf(stdout, "bss test\n"); + for(i = 0; i < sizeof(uninit); i++){ + if(uninit[i] != '\0'){ + printf(stdout, "bss test failed\n"); + exit(); + } + } + printf(stdout, "bss test ok\n"); +} + int main(int argc, char *argv[]) { @@ -1430,6 +1445,7 @@ main(int argc, char *argv[]) } close(open("usertests.ran", O_CREATE)); + bsstest(); sbrktest(); validatetest();