setsockopt(2)


NAME

   getsockopt, setsockopt - get and set options on sockets

SYNOPSIS

   #include <sys/types.h>          /* See NOTES */
   #include <sys/socket.h>

   int getsockopt(int sockfd, int level, int optname,
                  void *optval, socklen_t *optlen);
   int setsockopt(int sockfd, int level, int optname,
                  const void *optval, socklen_t optlen);

DESCRIPTION

   getsockopt()   and  setsockopt()  manipulate  options  for  the  socket
   referred to by the  file  descriptor  sockfd.   Options  may  exist  at
   multiple  protocol  levels;  they  are  always present at the uppermost
   socket level.

   When manipulating socket options, the level at which the option resides
   and the name of the option must be specified.  To manipulate options at
   the sockets API level, level is specified as SOL_SOCKET.  To manipulate
   options  at  any  other  level  the  protocol number of the appropriate
   protocol controlling the option is supplied.  For example, to  indicate
   that  an  option is to be interpreted by the TCP protocol, level should
   be set to the protocol number of TCP; see getprotoent(3).

   The arguments optval and optlen are used to access  option  values  for
   setsockopt().   For  getsockopt()  they  identify a buffer in which the
   value  for  the  requested  option(s)  are   to   be   returned.    For
   getsockopt(),  optlen  is a value-result argument, initially containing
   the size of the buffer pointed to by optval, and modified on return  to
   indicate  the actual size of the value returned.  If no option value is
   to be supplied or returned, optval may be NULL.

   Optname and any specified  options  are  passed  uninterpreted  to  the
   appropriate  protocol  module  for  interpretation.   The  include file
   <sys/socket.h> contains definitions for socket level options, described
   below.   Options  at  other  protocol  levels  vary in format and name;
   consult the appropriate entries in section 4 of the manual.

   Most socket-level options utilize an  int  argument  for  optval.   For
   setsockopt(),  the  argument  should  be  nonzero  to  enable a boolean
   option, or zero if the option is to be disabled.

   For a description of the available socket options see socket(7) and the
   appropriate protocol man pages.

RETURN VALUE

   On success, zero is returned for the standard options.  On error, -1 is
   returned, and errno is set appropriately.

   Netfilter allows the programmer to define custom  socket  options  with
   associated  handlers;  for such options, the return value on success is
   the value returned by the handler.

ERRORS

   EBADF     The argument sockfd is not a valid file descriptor.

   EFAULT    The address pointed to by optval is not in a  valid  part  of
             the  process address space.  For getsockopt(), this error may
             also be returned if optlen is not in  a  valid  part  of  the
             process address space.

   EINVAL    optlen invalid in setsockopt().  In some cases this error can
             also occur for an invalid value  in  optval  (e.g.,  for  the
             IP_ADD_MEMBERSHIP option described in ip(7)).

   ENOPROTOOPT
             The option is unknown at the level indicated.

   ENOTSOCK  The file descriptor sockfd does not refer to a socket.

CONFORMING TO

   POSIX.1-2001,  POSIX.1-2008,  SVr4,  4.4BSD  (these  system calls first
   appeared in 4.2BSD).

NOTES

   POSIX.1 does not require  the  inclusion  of  <sys/types.h>,  and  this
   header  file  is not required on Linux.  However, some historical (BSD)
   implementations required this header file,  and  portable  applications
   are probably wise to include it.

   For background on the socklen_t type, see accept(2).

BUGS

   Several  of the socket options should be handled at lower levels of the
   system.

SEE ALSO

   ioctl(2), socket(2), getprotoent(3),  protocols(5),  ip(7),  packet(7),
   socket(7), tcp(7), udp(7), unix(7)

COLOPHON

   This  page  is  part of release 4.09 of the Linux man-pages project.  A
   description of the project, information about reporting bugs,  and  the
   latest     version     of     this    page,    can    be    found    at
   https://www.kernel.org/doc/man-pages/.





Opportunity


Personal Opportunity - Free software gives you access to billions of dollars of software at no cost. Use this software for your business, personal use or to develop a profitable skill. Access to source code provides access to a level of capabilities/information that companies protect though copyrights. Open source is a core component of the Internet and it is available to you. Leverage the billions of dollars in resources and capabilities to build a career, establish a business or change the world. The potential is endless for those who understand the opportunity.

Business Opportunity - Goldman Sachs, IBM and countless large corporations are leveraging open source to reduce costs, develop products and increase their bottom lines. Learn what these companies know about open source and how open source can give you the advantage.





Free Software


Free Software provides computer programs and capabilities at no cost but more importantly, it provides the freedom to run, edit, contribute to, and share the software. The importance of free software is a matter of access, not price. Software at no cost is a benefit but ownership rights to the software and source code is far more significant.


Free Office Software - The Libre Office suite provides top desktop productivity tools for free. This includes, a word processor, spreadsheet, presentation engine, drawing and flowcharting, database and math applications. Libre Office is available for Linux or Windows.





Free Books


The Free Books Library is a collection of thousands of the most popular public domain books in an online readable format. The collection includes great classical literature and more recent works where the U.S. copyright has expired. These books are yours to read and use without restrictions.


Source Code - Want to change a program or know how it works? Open Source provides the source code for its programs so that anyone can use, modify or learn how to write those programs themselves. Visit the GNU source code repositories to download the source.





Education


Study at Harvard, Stanford or MIT - Open edX provides free online courses from Harvard, MIT, Columbia, UC Berkeley and other top Universities. Hundreds of courses for almost all major subjects and course levels. Open edx also offers some paid courses and selected certifications.


Linux Manual Pages - A man or manual page is a form of software documentation found on Linux/Unix operating systems. Topics covered include computer programs (including library and system calls), formal standards and conventions, and even abstract concepts.