⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mq_send.c

📁 UNIX网络编程 第2卷 进程间通信 代码
💻 C
字号:
/* include mq_send1 */#include	"unpipc.h"#include	"mqueue.h"intmymq_send(mymqd_t mqd, const char *ptr, size_t len, unsigned int prio){	int		n;	long	index, freeindex;	int8_t	*mptr;	struct sigevent	*sigev;	struct mymq_hdr	*mqhdr;	struct mymq_attr	*attr;	struct mymsg_hdr	*msghdr, *nmsghdr, *pmsghdr;	struct mymq_info	*mqinfo;	mqinfo = mqd;	if (mqinfo->mqi_magic != MQI_MAGIC) {		errno = EBADF;		return(-1);	}	mqhdr = mqinfo->mqi_hdr;	/* struct pointer */	mptr = (int8_t *) mqhdr;	/* byte pointer */	attr = &mqhdr->mqh_attr;	if ( (n = pthread_mutex_lock(&mqhdr->mqh_lock)) != 0) {		errno = n;		return(-1);	}	if (len > attr->mq_msgsize) {		errno = EMSGSIZE;		goto err;	}	if (attr->mq_curmsgs == 0) {		if (mqhdr->mqh_pid != 0 && mqhdr->mqh_nwait == 0) {			sigev = &mqhdr->mqh_event;			if (sigev->sigev_notify == SIGEV_SIGNAL) {				sigqueue(mqhdr->mqh_pid, sigev->sigev_signo,						 sigev->sigev_value);			}			mqhdr->mqh_pid = 0;		/* unregister */		}	} else if (attr->mq_curmsgs >= attr->mq_maxmsg) {			/* 4queue is full */		if (mqinfo->mqi_flags & O_NONBLOCK) {			errno = EAGAIN;			goto err;		}			/* 4wait for room for one message on the queue */		while (attr->mq_curmsgs >= attr->mq_maxmsg)			pthread_cond_wait(&mqhdr->mqh_wait, &mqhdr->mqh_lock);	}/* end mq_send1 *//* include mq_send2 */		/* 4nmsghdr will point to new message */	if ( (freeindex = mqhdr->mqh_free) == 0)		err_dump("mymq_send: curmsgs = %ld; free = 0", attr->mq_curmsgs);	nmsghdr = (struct mymsg_hdr *) &mptr[freeindex];	nmsghdr->msg_prio = prio;	nmsghdr->msg_len = len;	memcpy(nmsghdr + 1, ptr, len);		/* copy message from caller */	mqhdr->mqh_free = nmsghdr->msg_next;	/* new freelist head */		/* 4find right place for message in linked list */	index = mqhdr->mqh_head;	pmsghdr = (struct mymsg_hdr *) &(mqhdr->mqh_head);	while (index != 0) {		msghdr = (struct mymsg_hdr *) &mptr[index];		if (prio > msghdr->msg_prio) {			nmsghdr->msg_next = index;			pmsghdr->msg_next = freeindex;			break;		}		index = msghdr->msg_next;		pmsghdr = msghdr;	}	if (index == 0) {			/* 4queue was empty or new goes at end of list */		pmsghdr->msg_next = freeindex;		nmsghdr->msg_next = 0;	}		/* 4wake up anyone blocked in mq_receive waiting for a message */	if (attr->mq_curmsgs == 0)		pthread_cond_signal(&mqhdr->mqh_wait);	attr->mq_curmsgs++;	pthread_mutex_unlock(&mqhdr->mqh_lock);	return(0);err:	pthread_mutex_unlock(&mqhdr->mqh_lock);	return(-1);}/* end mq_send2 */voidMymq_send(mymqd_t mqd, const char *ptr, size_t len, unsigned int prio){	if (mymq_send(mqd, ptr, len, prio) == -1)		err_sys("mymq_send error");}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -