iofunc_write_default()
Default handler for _IO_WRITE messages
Synopsis:
#include <sys/iofunc.h> int iofunc_write_default( resmgr_context_t* ctp, io_write_t* msg, iofunc_ocb_t* ocb );
Arguments:
- ctp
- A pointer to a resmgr_context_t structure that the resource-manager library uses to pass context information between functions.
- msg
- A pointer to the io_write_t structure that contains the message that the resource manager received. For more information, see iofunc_write_verify().
- ocb
- A pointer to the iofunc_ocb_t structure for the Open Control Block that was created when the client opened the resource.
Library:
libc
Use the -l c option to qcc to link against this library. This library is usually included automatically.
Description:
The iofunc_write_default() function implements POSIX semantics for the client's write() call, which is received as an _IO_WRITE message by the resource manager.
You can place this function directly into the io_funcs table passed to resmgr_attach() , at the write position, or you can call iofunc_func_init() to initialize all of the functions to their default values.
The iofunc_write_default() function calls iofunc_write_verify() to verify the permissions on the file. If the permissions are correct, iofunc_write_default() indicates that it wrote zero bytes.
Returns:
- EBADF
- The client doesn't have write access to this resource.
- EINVAL
- An unknown xtype was given.
- EOK
- The client has write access to this resource.
Classification:
Safety: | |
---|---|
Cancellation point | No |
Interrupt handler | No |
Signal handler | Yes |
Thread | Yes |