mread.c revision 7c478bd95313f5f23a4c958a745db2134aa03244
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
/* All Rights Reserved */
#ident "%Z%%M% %I% %E% SMI" /* SVr4.0 1.6 */
/* LINTLIBRARY */
#include <errno.h>
#include <fcntl.h>
#include <string.h>
#include <stropts.h>
#include "lp.h"
#include "msgs.h"
extern int Lp_prio_msg;
/*
** Function: int mread( MESG *, char *, int)
** Args: message descriptor
** message buffer (var)
** buffer size
** Return: The size of the message in message buffer.
** or -1 on error. Possible errnos are:
** EINVAL Bad value for md or msgbuf.
** E2BIG Not enough space for message.
** EPIPE Far end dropped the connection.
** ENOMSG No valid message available on fifo.
**
** mread examines message descriptor and either calls read3_2
** to read 3.2 HPI messages or getmsg(2) to read 4.0 HPI messages.
** If a message is read, it is returned in message buffer.
*/
#if defined(__STDC__)
int mread ( MESG * md, char * msgbuf, int size )
#else
int mread ( md, msgbuf, size )
MESG *md;
char *msgbuf;
int size;
#endif
{
int flag = 0;
char buff [MSGMAX];
struct strbuf dat;
struct strbuf ctl;
if (md == NULL || msgbuf == NULL)
{
errno = EINVAL;
return(-1);
}
switch(md->type)
{
case MD_CHILD:
case MD_STREAM:
case MD_BOUND:
if (size <= 0)
{
errno = E2BIG;
return(-1);
}
dat.buf = msgbuf;
dat.maxlen = size;
dat.len = 0;
ctl.buf = buff;
ctl.maxlen = sizeof (buff);
ctl.len = 0;
flag = Lp_prio_msg;
Lp_prio_msg = 0; /* clean this up so there are no surprises */
if (Getmsg(md, &ctl, &dat, &flag) < 0)
{
if (errno == EBADF)
errno = EPIPE;
return(-1);
}
if (dat.len == 0)
{
(void) Close(md->readfd);
return(0);
}
break;
case MD_USR_FIFO:
case MD_SYS_FIFO:
if (size < CONTROL_LEN)
{
errno = E2BIG;
return(-1);
}
if (read3_2(md, msgbuf, size) < 0)
return(-1);
break;
}
return((int)msize(msgbuf));
}