mirror of
https://github.com/torvalds/linux
synced 2024-11-05 18:23:50 +00:00
0d6038ee76
This sockopt goes in line with SO_TYPE and SO_PROTOCOL. It makes it possible for userspace programs to pass around file descriptors — I am referring to arguments-to-functions, but it may even work for the fd passing over UNIX sockets — without needing to also pass the auxiliary information (PF_INET6/IPPROTO_TCP). Signed-off-by: Jan Engelhardt <jengelh@medozas.de> Signed-off-by: David S. Miller <davem@davemloft.net>
64 lines
1.5 KiB
C
64 lines
1.5 KiB
C
#ifndef _ASM_SOCKET_H
|
|
#define _ASM_SOCKET_H
|
|
|
|
#include <asm/sockios.h>
|
|
|
|
/* For setsockopt(2) */
|
|
#define SOL_SOCKET 0xffff
|
|
|
|
#define SO_DEBUG 0x0001
|
|
#define SO_PASSCRED 0x0002
|
|
#define SO_REUSEADDR 0x0004
|
|
#define SO_KEEPALIVE 0x0008
|
|
#define SO_DONTROUTE 0x0010
|
|
#define SO_BROADCAST 0x0020
|
|
#define SO_PEERCRED 0x0040
|
|
#define SO_LINGER 0x0080
|
|
#define SO_OOBINLINE 0x0100
|
|
/* To add :#define SO_REUSEPORT 0x0200 */
|
|
#define SO_BSDCOMPAT 0x0400
|
|
#define SO_RCVLOWAT 0x0800
|
|
#define SO_SNDLOWAT 0x1000
|
|
#define SO_RCVTIMEO 0x2000
|
|
#define SO_SNDTIMEO 0x4000
|
|
#define SO_ACCEPTCONN 0x8000
|
|
|
|
#define SO_SNDBUF 0x1001
|
|
#define SO_RCVBUF 0x1002
|
|
#define SO_SNDBUFFORCE 0x100a
|
|
#define SO_RCVBUFFORCE 0x100b
|
|
#define SO_ERROR 0x1007
|
|
#define SO_TYPE 0x1008
|
|
#define SO_PROTOCOL 0x1028
|
|
#define SO_DOMAIN 0x1029
|
|
|
|
|
|
/* Linux specific, keep the same. */
|
|
#define SO_NO_CHECK 0x000b
|
|
#define SO_PRIORITY 0x000c
|
|
|
|
#define SO_BINDTODEVICE 0x000d
|
|
|
|
#define SO_ATTACH_FILTER 0x001a
|
|
#define SO_DETACH_FILTER 0x001b
|
|
|
|
#define SO_PEERNAME 0x001c
|
|
#define SO_TIMESTAMP 0x001d
|
|
#define SCM_TIMESTAMP SO_TIMESTAMP
|
|
|
|
#define SO_PEERSEC 0x001e
|
|
#define SO_PASSSEC 0x001f
|
|
#define SO_TIMESTAMPNS 0x0021
|
|
#define SCM_TIMESTAMPNS SO_TIMESTAMPNS
|
|
|
|
#define SO_MARK 0x0022
|
|
|
|
#define SO_TIMESTAMPING 0x0023
|
|
#define SCM_TIMESTAMPING SO_TIMESTAMPING
|
|
|
|
/* Security levels - as per NRL IPv6 - don't actually do anything */
|
|
#define SO_SECURITY_AUTHENTICATION 0x5001
|
|
#define SO_SECURITY_ENCRYPTION_TRANSPORT 0x5002
|
|
#define SO_SECURITY_ENCRYPTION_NETWORK 0x5004
|
|
|
|
#endif /* _ASM_SOCKET_H */
|