Man Linux: Main Page and Category List

NAME

       vrb_init_opt - initialize a virtual ring buffer

LIBRARY

       -lvrb

SYNOPSIS

       #include <vrb.h>

       vrb_p  vrb_init_opt(vrb_p  vrb,  size_t  size,  const  char  *name, int
       options);

DESCRIPTION

       vrb_init_opt Initialize a static or pre-allocated virtual  ring  buffer
       structure.

       A  virtual  ring  buffer  is  a  character  FIFO queue with the special
       property that any sequence of characters in the buffer may be  accessed
       as  a  single contiguous block of memory, eliminating the need to split
       any sequence to handle a buffer wraparound.

ARGUMENTS

       vrb_p vrb
       specifies the virtual ring buffer structure  to  be  initialized.   The
       caller  must  release  buffer  resources  via  vrb_uninit(3)  when this
       virtual ring buffer is no longer needed.   If  NULL  is  given,  a  new
       virtual  ring buffer structure is allocated and the caller must release
       buffer resources via vrb_destroy(3)  when  an  allocated  virtual  ring
       buffer is no longer needed.

       size_t size
       specifies the requested minimum buffer size to be allocated.  The given
       value will be rounded up to the nearest or equal whole multiple of  the
       system  page  size.   The virtual ring buffer is implemented by mapping
       two adjacent blocks of memory to the same memory object.   Thus,  twice
       as  much virtual address space will be used and the specified size must
       be less than half of the  available  virtual  address  space  for  this
       process.

       const char *name
       specifies  an  optional  temporary  name pattern or an actual name of a
       file to be used as backing store via mmap(2) in a mounted filesystem in
       which  the  process  has  write permission.  If the name string ends in
       "XXXXXX" then  mkstemp(3)  will  be  used  to  make  the  file  unique.
       Otherwise  it  will be used as is.  If the named file already exists or
       otherwise cannot be opened for write, an error will occur.  If NULL  is
       given, swap space will be used as backing store via shmat(2).

       int options
       specifies  option flags that may be given to alter the behaviour of the
       virtual ring buffer.  The implemented options are:

       VRB_NOGUARD
              Do not include guard pages that  would  protect  against  buffer
              overflow errors.

       VRB_ENVGUARD
              Override  VRB_NOGUARD  if  the  environment variable VRBGUARD is
              defined with a value other than the string "0".

RETURN VALUE

       vrb_p
       On success, a handle (pointer) to the newly created virtual ring buffer
       is returned.  On error, NULL is returned.

ERRORS

       If  an  error  is  returned,  then errno will have one of the following
       values:

       EINVAL A buffer size was requested which is too large for address space
              allocation arithmetic.

       ENOMEM Out of memory allocating the virtual ring buffer structure.

       -      An errno value set by a failing system call.

SEE ALSO

       vrb(3),      vrb_capacity(3),     vrb_data_len(3),     vrb_data_ptr(3),
       vrb_destroy(3), vrb_get(3), vrb_get_min(3),  vrb_give(3),  vrb_init(3),
       vrb_is_empty(3),          vrb_is_full(3),          vrb_is_not_empty(3),
       vrb_is_not_full(3),    vrb_move(3),     vrb_new(3),     vrb_new_opt(3),
       vrb_put(3),      vrb_put_all(3),      vrb_read(3),     vrb_read_min(3),
       vrb_resize(3),   vrb_space_len(3),    vrb_space_ptr(3),    vrb_take(3),
       vrb_uninit(3), vrb_write(3), vrb_write_min(3)