C Семафоры Unix: процесс должен ждать 0, но не

Написали две простые функции, одну для установки семафора в произвольное значение (Reset) и другую, чтобы заставить вызывающий его процесс ждать, пока семафор станет равным нулю:

int R(int semid, int semnum, int val)   // reset
{
    union semun arg;
    arg.val = val;
    if( semctl(sem_id,semnum,SETVAL,arg) == -1 )  
    {
        fprintf (stderr, "Errore inizializzazione del semaforo\n%s\n",
                strerror(errno) );
    }
}

int Z(int semid, int semnum)    // wait for zero
{
        printf("waiting for zero on %d\n",semid);
        struct sembuf cmd;
        cmd.sem_num = semnum;
        cmd.sem_op = 0;
        cmd.sem_flg = 0;
        if(semop(semid, &cmd, 1)<0) {ERROR}
        return 0;
}

Процесс, который использует эти функции как код, который выглядит следующим образом:

while(1) {
    R(sem_id_counter,0,N_PROC_DEFAULT);  // (N_PROC_DEFAULT=5)

    /* list of tasks not having anything to do with sem_id_coutner */

    Z(sem_id_counter,0);
}

То, что происходит, - то, что вышеупомянутый процесс просто продолжает выполнять цикл, в то время как я хочу, чтобы он остановился в конце, когда он вызывает функцию Z, ожидая, пока семафор станет 0, прежде чем сбросить его в исходное содержимое и перезапустить.

Куда я иду не так? Спасибо [решено: глупая опечатка sem_id вместо semid ]

0 ответов

Другие вопросы по тегам