LDI_PUTMSG(9F)          Kernel Functions for Drivers          LDI_PUTMSG(9F)
NAME
       ldi_putmsg, ldi_getmsg - Read/write message blocks from/to a stream
SYNOPSIS
       #include <sys/sunldi.h>       
int ldi_putmsg(
ldi_handle_t lh, 
mblk_t *smp);       
int  ldi_getmsg(
ldi_handle_t lh, 
mblk_t **rmp, 
timestruc_t *timeo);
PARAMETERS
       lh                 Layered handle.       
smp                 Message block to send.       
rmp                 Message block to receive.       
timeo                 Optional timeout for data reception.
DESCRIPTION
       The 
ldi_putmsg function allows a caller to send a message block to a
       streams device specified by the layered handle 
lh. Once the message
       (smp) has been passed to 
ldi_putmsg(), the caller must not free the
       message even if an error occurs.
       The 
ldi_getmsg() function allows a caller to receive a message block
       from a streams device specified by the layered handle 
lh. Callers
       must free the message received with 
freemsg(9F).
       If a NULL timeout value is specified when the caller receives a
       message, the caller sleeps until a message is received.
RETURN VALUES
       The 
ldi_putmsg() and 
ldi_getmsg() functions return 
0 upon success. If
       a failure occurs before the request is passed to the device, the
       possible return values are shown below. Otherwise any other error
       number may be returned by the device.       
EINVAL                  Invalid input parameters.       
ENOTSUP                  Operation is not supported for this device.
                  The 
ldi_getmsg() function may also return:                  
ETIME                           Returned if the timeout 
timeo expires with no
                           messages received.
CONTEXT
       These functions may be called from user or kernel context.
                                June 3, 2003                  LDI_PUTMSG(9F)