2006-07-16 17:36:31 +02:00
|
|
|
#include "user.h"
|
|
|
|
|
2006-07-01 23:26:01 +02:00
|
|
|
char buf[2048];
|
2006-06-27 16:35:53 +02:00
|
|
|
|
2006-07-11 19:39:45 +02:00
|
|
|
// simple fork and pipe read/write
|
|
|
|
|
2006-06-27 16:35:53 +02:00
|
|
|
void
|
2006-07-17 03:25:22 +02:00
|
|
|
pipe1(void)
|
2006-06-27 16:35:53 +02:00
|
|
|
{
|
|
|
|
int fds[2], pid;
|
2006-07-01 23:26:01 +02:00
|
|
|
int seq = 0, i, n, cc, total;
|
2006-06-27 16:35:53 +02:00
|
|
|
|
|
|
|
pipe(fds);
|
2006-07-01 23:26:01 +02:00
|
|
|
pid = fork();
|
2006-06-27 16:35:53 +02:00
|
|
|
if(pid == 0){
|
2006-07-01 23:26:01 +02:00
|
|
|
close(fds[0]);
|
|
|
|
for(n = 0; n < 5; n++){
|
|
|
|
for(i = 0; i < 1033; i++)
|
|
|
|
buf[i] = seq++;
|
|
|
|
if(write(fds[1], buf, 1033) != 1033){
|
2006-07-15 14:03:57 +02:00
|
|
|
panic("pipe1 oops 1\n");
|
2006-07-16 17:36:31 +02:00
|
|
|
exit();
|
2006-07-01 23:26:01 +02:00
|
|
|
}
|
|
|
|
}
|
2006-07-16 17:36:31 +02:00
|
|
|
exit();
|
2006-06-27 16:35:53 +02:00
|
|
|
} else {
|
2006-07-01 23:26:01 +02:00
|
|
|
close(fds[1]);
|
|
|
|
total = 0;
|
|
|
|
cc = 1;
|
2006-07-17 03:25:22 +02:00
|
|
|
while((n = read(fds[0], buf, cc)) > 0){
|
2006-07-01 23:26:01 +02:00
|
|
|
for(i = 0; i < n; i++){
|
|
|
|
if((buf[i] & 0xff) != (seq++ & 0xff)){
|
2006-07-15 14:03:57 +02:00
|
|
|
panic("pipe1 oops 2\n");
|
2006-07-01 23:26:01 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
total += n;
|
|
|
|
cc = cc * 2;
|
|
|
|
if(cc > sizeof(buf))
|
|
|
|
cc = sizeof(buf);
|
2006-06-27 16:35:53 +02:00
|
|
|
}
|
2006-07-01 23:26:01 +02:00
|
|
|
if(total != 5 * 1033)
|
2006-07-15 14:03:57 +02:00
|
|
|
panic("pipe1 oops 3\n");
|
2006-07-01 23:26:01 +02:00
|
|
|
close(fds[0]);
|
2006-07-15 14:03:57 +02:00
|
|
|
wait();
|
2006-06-27 16:35:53 +02:00
|
|
|
}
|
|
|
|
puts("pipe1 ok\n");
|
|
|
|
}
|
|
|
|
|
2006-07-11 19:39:45 +02:00
|
|
|
// meant to be run w/ at most two CPUs
|
|
|
|
void
|
2006-07-17 03:25:22 +02:00
|
|
|
preempt(void)
|
2006-07-11 19:39:45 +02:00
|
|
|
{
|
|
|
|
int pid1, pid2, pid3;
|
|
|
|
int pfds[2];
|
|
|
|
|
|
|
|
pid1 = fork();
|
|
|
|
if(pid1 == 0)
|
2006-07-17 03:25:22 +02:00
|
|
|
for(;;)
|
2006-07-11 19:39:45 +02:00
|
|
|
;
|
|
|
|
|
|
|
|
pid2 = fork();
|
|
|
|
if(pid2 == 0)
|
2006-07-17 03:25:22 +02:00
|
|
|
for(;;)
|
2006-07-11 19:39:45 +02:00
|
|
|
;
|
|
|
|
|
|
|
|
pipe(pfds);
|
|
|
|
pid3 = fork();
|
|
|
|
if(pid3 == 0){
|
|
|
|
close(pfds[0]);
|
|
|
|
if(write(pfds[1], "x", 1) != 1)
|
2006-07-15 14:03:57 +02:00
|
|
|
panic("preempt write error");
|
2006-07-11 19:39:45 +02:00
|
|
|
close(pfds[1]);
|
2006-07-17 03:25:22 +02:00
|
|
|
for(;;)
|
2006-07-11 19:39:45 +02:00
|
|
|
;
|
|
|
|
}
|
|
|
|
|
|
|
|
close(pfds[1]);
|
|
|
|
if(read(pfds[0], buf, sizeof(buf)) != 1){
|
2006-07-15 14:03:57 +02:00
|
|
|
panic("preempt read error");
|
2006-07-11 19:39:45 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
close(pfds[0]);
|
|
|
|
kill(pid1);
|
|
|
|
kill(pid2);
|
|
|
|
kill(pid3);
|
|
|
|
wait();
|
|
|
|
wait();
|
|
|
|
wait();
|
|
|
|
puts("preempt ok\n");
|
|
|
|
}
|
|
|
|
|
2006-07-15 14:03:57 +02:00
|
|
|
// try to find any races between exit and wait
|
|
|
|
void
|
2006-07-17 03:25:22 +02:00
|
|
|
exitwait(void)
|
2006-07-15 14:03:57 +02:00
|
|
|
{
|
|
|
|
int i, pid;
|
|
|
|
|
|
|
|
for(i = 0; i < 100; i++){
|
|
|
|
pid = fork();
|
|
|
|
if(pid < 0){
|
|
|
|
panic("fork failed\n");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if(pid){
|
|
|
|
if(wait() != pid){
|
|
|
|
panic("wait wrong pid\n");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
} else {
|
2006-07-16 17:36:31 +02:00
|
|
|
exit();
|
2006-07-15 14:03:57 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
puts("exitwait ok\n");
|
|
|
|
}
|
|
|
|
|
2006-07-16 17:36:31 +02:00
|
|
|
int
|
2006-07-29 00:33:07 +02:00
|
|
|
main(int argc, char *argv[])
|
2006-06-27 16:35:53 +02:00
|
|
|
{
|
2006-07-11 19:39:45 +02:00
|
|
|
puts("usertests starting\n");
|
2006-07-15 14:03:57 +02:00
|
|
|
|
2006-07-12 17:35:33 +02:00
|
|
|
pipe1();
|
2006-07-15 14:03:57 +02:00
|
|
|
preempt();
|
|
|
|
exitwait();
|
2006-06-27 16:35:53 +02:00
|
|
|
|
2006-07-16 17:36:31 +02:00
|
|
|
panic("usertests succeeded");
|
|
|
|
return 0;
|
2006-06-27 16:35:53 +02:00
|
|
|
}
|