Newer
Older
// simple fork and pipe read/write
if(pipe(fds) != 0){
puts("pipe() failed\n");
exit();
}
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){
for(i = 0; i < n; i++){
if((buf[i] & 0xff) != (seq++ & 0xff)){
return;
}
}
total += n;
cc = cc * 2;
if(cc > sizeof(buf))
cc = sizeof(buf);
printf(1, "pipe1 oops 3 total %d\n", total);
} else {
puts("fork() failed\n");
exit();
// meant to be run w/ at most two CPUs
void
{
int pid1, pid2, pid3;
int pfds[2];
pid1 = fork();
if(pid1 == 0)
;
pid2 = fork();
if(pid2 == 0)
;
pipe(pfds);
pid3 = fork();
if(pid3 == 0){
close(pfds[0]);
if(write(pfds[1], "x", 1) != 1)
;
}
close(pfds[1]);
if(read(pfds[0], buf, sizeof(buf)) != 1){
return;
}
close(pfds[0]);
kill(pid1);
kill(pid2);
kill(pid3);
wait();
wait();
wait();
puts("preempt ok\n");
}
{
int i, pid;
for(i = 0; i < 100; i++){
pid = fork();
if(pid < 0){
if((pid = fork()) == 0){
m1 = 0;
while ((m2 = malloc(10001)) != 0) {
*(char **) m2 = m1;
m1 = m2;
}
while (m1) {
m2 = *(char **)m1;
free(m1);
m1 = m2;
}
m1 = malloc(1024*20);
if (m1 == 0) {
puts("couldn't allocate mem?!!\n");
exit();
}