Man Linux: Main Page and Category List

NAME

       vrb_resize - create a new virtual ring buffer

LIBRARY

       -lvrb

SYNOPSIS

       #include <vrb.h>

       vrb_p vrb_resize(size_t size, const char *name);

DESCRIPTION

       vrb_resize changes the size of a virtual ring buffer if the data in the
       source buffer will fit in the requested space.

ARGUMENTS

       vrb_p vrb
       specifies the ring buffer which will be resized.

       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 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 named file cannot be opened  for  write,  an  error
       will occur.  If NULL is given, swap space will be used as backing store
       via shmat(2).

RETURN VALUE

       int
       On success, 0 is returned.  Otherwise, -1 is returned.

ERRORS

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

       ENOSPC The  data  in  the current virtual ring buffer will not fit into
              the requested space.

       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_init_opt(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_space_len(3),   vrb_space_ptr(3),    vrb_take(3),    vrb_uninit(3),
       vrb_write(3), vrb_write_min(3)