#define _SYSTEM 1 #define _MINIX_SYSTEM 1 #include #include #include "namespace.h" #include #include #include #include #include #include #include #include #include static int get_ipc_endpt(endpoint_t *pt) { return minix_rs_lookup("ipc", pt); } /* Get semaphore. */ int semget(key_t key, int nsems, int semflag) { message m; endpoint_t ipc_pt; int r; if (get_ipc_endpt(&ipc_pt) != OK) { errno = ENOSYS; return -1; } memset(&m, 0, sizeof(m)); m.m_lc_ipc_semget.key = key; m.m_lc_ipc_semget.nr = nsems; m.m_lc_ipc_semget.flag = semflag; r = _syscall(ipc_pt, IPC_SEMGET, &m); if (r != OK) return r; return m.m_lc_ipc_semget.retid; } /* Semaphore control operation. */ int semctl(int semid, int semnum, int cmd, ...) { message m; endpoint_t ipc_pt; va_list ap; int r; if (get_ipc_endpt(&ipc_pt) != OK) { errno = ENOSYS; return -1; } memset(&m, 0, sizeof(m)); m.m_lc_ipc_semctl.id = semid; m.m_lc_ipc_semctl.num = semnum; m.m_lc_ipc_semctl.cmd = cmd; va_start(ap, cmd); switch (cmd) { case SETVAL: m.m_lc_ipc_semctl.opt = (vir_bytes)va_arg(ap, int); break; case IPC_STAT: case IPC_SET: case IPC_INFO: case SEM_INFO: case SEM_STAT: case GETALL: case SETALL: m.m_lc_ipc_semctl.opt = (vir_bytes)va_arg(ap, void *); break; default: m.m_lc_ipc_semctl.opt = 0; break; } va_end(ap); r = _syscall(ipc_pt, IPC_SEMCTL, &m); if ((r != -1) && (cmd == GETNCNT || cmd == GETZCNT || cmd == GETPID || cmd == GETVAL || cmd == IPC_INFO || cmd == SEM_INFO || cmd == SEM_STAT)) return m.m_lc_ipc_semctl.ret; return r; } /* Operate on semaphore. */ int semop(int semid, struct sembuf *sops, size_t nsops) { message m; endpoint_t ipc_pt; if (get_ipc_endpt(&ipc_pt) != OK) { errno = ENOSYS; return -1; } memset(&m, 0, sizeof(m)); m.m_lc_ipc_semop.id = semid; m.m_lc_ipc_semop.ops = sops; m.m_lc_ipc_semop.size = nsops; return _syscall(ipc_pt, IPC_SEMOP, &m); }