 3f38115c7b
			
		
	
	
		3f38115c7b
		
	
	
	
	
		
			
			. define _MINIX_SYSTEM for all system code from minix.service.mk . hide some system-level declarations and definitions behind _MINIX_SYSTEM to cleanly fix host tool build problems on Minix (such as: NONE being defined and paddr_t being used but not declared) . the similar definition _SYSTEM is unsuitable as it changes the values of errno definitions Change-Id: I407de79e2575115243a074b16e79546a279cfa3e
		
			
				
	
	
		
			100 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #define __USE_MISC
 | |
| #define _SYSTEM	1
 | |
| #define _MINIX_SYSTEM	1
 | |
| 
 | |
| #include <sys/cdefs.h>
 | |
| #include <lib.h>
 | |
| #include "namespace.h"
 | |
| 
 | |
| #include <lib.h>
 | |
| #include <minix/rs.h>
 | |
| 
 | |
| #include <sys/types.h>
 | |
| #include <sys/ipc.h>
 | |
| #include <sys/sem.h>
 | |
| #include <stdlib.h>
 | |
| #include <stdarg.h>
 | |
| #include <errno.h>
 | |
| #include <string.h>
 | |
| 
 | |
| 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.SEMGET_KEY = key;
 | |
| 	m.SEMGET_NR = nsems;
 | |
| 	m.SEMGET_FLAG = semflag;
 | |
| 
 | |
| 	r = _syscall(ipc_pt, IPC_SEMGET, &m);
 | |
| 	if (r != OK)
 | |
| 		return r;
 | |
| 
 | |
| 	return m.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.SEMCTL_ID = semid;
 | |
| 	m.SEMCTL_NUM = semnum;
 | |
| 	m.SEMCTL_CMD = cmd;
 | |
| 	va_start(ap, cmd);
 | |
| 	if (cmd == IPC_STAT || cmd == IPC_SET || cmd == IPC_INFO ||
 | |
| 		cmd == SEM_INFO || cmd == SEM_STAT || cmd == GETALL ||
 | |
| 		cmd == SETALL || cmd == SETVAL)
 | |
| 		m.SEMCTL_OPT = (long) va_arg(ap, long);
 | |
| 	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.SHMCTL_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.SEMOP_ID = semid;
 | |
| 	m.SEMOP_OPS = (long) sops;
 | |
| 	m.SEMOP_SIZE = nsops;
 | |
| 
 | |
| 	return _syscall(ipc_pt, IPC_SEMOP, &m);
 | |
| }
 | |
| 
 |