jehanne/qa/kern/tsemacquire.c
2020-09-17 23:47:39 +02:00

116 lines
1.6 KiB
C

#include <u.h>
#include <lib9.h>
int32_t nprocs = 32;
int32_t nloops = 10000;
int32_t x = 1;
int32_t incr;
void
tsemloop(void)
{
int i;
i = 0;
while(i < nloops){
if(tsemacquire(&x, 10)){
if((i % 1000) == 0)
sleep(10);
incr++;
i++;
sys_semrelease(&x, 1);
} else {
//print("pid %d timeout\n", getpid());
}
}
exits("PASS");
}
void
semloop(void)
{
int i;
i = 0;
while(i < nloops){
if(sys_semacquire(&x, 1)){
incr++;
i++;
sys_semrelease(&x, 1);
} else {
sysfatal("semacquire failed");
}
}
}
void
main(void)
{
int i;
incr = 0;
for(i = 0; i < nprocs; i++){
switch(sys_rfork(RFMEM|RFPROC)){
case -1:
sysfatal("sys_rfork");
case 0:
tsemloop();
exits("PASS");
default:
break;
}
}
for(i = 0; i < nprocs; i++)
waitpid();
print("tsemloop incr %d\n", incr);
if(incr != nprocs*nloops){
print("FAIL\n");
exits("FAIL");
}
incr = 0;
for(i = 0; i < nprocs; i++){
switch(sys_rfork(RFMEM|RFPROC)){
case -1:
sysfatal("sys_rfork");
case 0:
semloop();
exits("PASS");
default:
break;
}
}
for(i = 0; i < nprocs; i++)
waitpid();
print("semloop incr %d\n", incr);
if(incr != nprocs*nloops){
print("FAIL\n");
exits("FAIL");
}
incr = 0;
for(i = 0; i < nprocs; i++){
switch(sys_rfork(RFMEM|RFPROC)){
case -1:
sysfatal("sys_rfork");
case 0:
if((i&1) == 0)
semloop();
else
tsemloop();
exits("PASS");
default:
break;
}
}
for(i = 0; i < nprocs; i++)
waitpid();
print("mixed incr %d\n", incr);
if(incr != nprocs*nloops){
print("FAIL\n");
exits("FAIL");
}
print("PASS\n");
exits("PASS");
}