mirror of
				https://git.proxmox.com/git/mirror_frr
				synced 2025-10-31 13:03:19 +00:00 
			
		
		
		
	 b33e46666d
			
		
	
	
		b33e46666d
		
	
	
	
	
		
			
			MD5 auth on TCP is supported for prefixes in recent versions of Linux; add complementary support for FRR. This is a reworked version of Donald's commit to keep library compatibility and obviate the need for changes in daemons that don't need to support this themselves. Signed-off-by: Quentin Young <qlyoung@cumulusnetworks.com>
		
			
				
	
	
		
			145 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			145 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Router advertisement
 | |
|  * Copyright (C) 1999 Kunihiro Ishiguro
 | |
|  *
 | |
|  * This file is part of GNU Zebra.
 | |
|  *
 | |
|  * GNU Zebra is free software; you can redistribute it and/or modify it
 | |
|  * under the terms of the GNU General Public License as published by the
 | |
|  * Free Software Foundation; either version 2, or (at your option) any
 | |
|  * later version.
 | |
|  *
 | |
|  * GNU Zebra is distributed in the hope that it will be useful, but
 | |
|  * WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License along
 | |
|  * with this program; see the file COPYING; if not, write to the Free Software
 | |
|  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
 | |
|  */
 | |
| 
 | |
| #ifndef _ZEBRA_SOCKOPT_H
 | |
| #define _ZEBRA_SOCKOPT_H
 | |
| 
 | |
| #include "sockunion.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| extern void setsockopt_so_recvbuf(int sock, int size);
 | |
| extern void setsockopt_so_sendbuf(const int sock, int size);
 | |
| extern int getsockopt_so_sendbuf(const int sock);
 | |
| 
 | |
| extern int setsockopt_ipv6_pktinfo(int, int);
 | |
| extern int setsockopt_ipv6_checksum(int, int);
 | |
| extern int setsockopt_ipv6_multicast_hops(int, int);
 | |
| extern int setsockopt_ipv6_unicast_hops(int, int);
 | |
| extern int setsockopt_ipv6_hoplimit(int, int);
 | |
| extern int setsockopt_ipv6_multicast_loop(int, int);
 | |
| extern int setsockopt_ipv6_tclass(int, int);
 | |
| 
 | |
| #define SOPT_SIZE_CMSG_PKTINFO_IPV6() (sizeof (struct in6_pktinfo));
 | |
| 
 | |
| /*
 | |
|  * Size defines for control messages used to get ifindex.  We define
 | |
|  * values for each method, and define a macro that can be used by code
 | |
|  * that is unaware of which method is in use.
 | |
|  * These values are without any alignment needed (see CMSG_SPACE in RFC3542).
 | |
|  */
 | |
| #if defined(IP_PKTINFO)
 | |
| /* Linux in_pktinfo. */
 | |
| #define SOPT_SIZE_CMSG_PKTINFO_IPV4()  (CMSG_SPACE(sizeof (struct in_pktinfo)))
 | |
| /* XXX This should perhaps be defined even if IP_PKTINFO is not. */
 | |
| #define SOPT_SIZE_CMSG_PKTINFO(af)                                             \
 | |
|   ((af == AF_INET) ? SOPT_SIZE_CMSG_PKTINFO_IPV4() \
 | |
|                    : SOPT_SIZE_CMSG_PKTINFO_IPV6()
 | |
| #endif /* IP_PKTINFO */
 | |
| 
 | |
| #if defined(IP_RECVIF)
 | |
| /* BSD/Solaris */
 | |
| 
 | |
| #if defined(SUNOS_5)
 | |
| #define SOPT_SIZE_CMSG_RECVIF_IPV4()  (sizeof (uint_t))
 | |
| #else
 | |
| #define SOPT_SIZE_CMSG_RECVIF_IPV4()	(sizeof (struct sockaddr_dl))
 | |
| #endif /* SUNOS_5 */
 | |
| #endif /* IP_RECVIF */
 | |
| 
 | |
| /* SOPT_SIZE_CMSG_IFINDEX_IPV4 - portable type */
 | |
| #if defined(SOPT_SIZE_CMSG_PKTINFO)
 | |
| #define SOPT_SIZE_CMSG_IFINDEX_IPV4() SOPT_SIZE_CMSG_PKTINFO_IPV4()
 | |
| #elif defined(SOPT_SIZE_CMSG_RECVIF_IPV4)
 | |
| #define SOPT_SIZE_CMSG_IFINDEX_IPV4() SOPT_SIZE_CMSG_RECVIF_IPV4()
 | |
| #else  /* Nothing available */
 | |
| #define SOPT_SIZE_CMSG_IFINDEX_IPV4() (sizeof (char *))
 | |
| #endif /* SOPT_SIZE_CMSG_IFINDEX_IPV4 */
 | |
| 
 | |
| #define SOPT_SIZE_CMSG_IFINDEX(af)                                             \
 | |
|   (((af) == AF_INET) : SOPT_SIZE_CMSG_IFINDEX_IPV4() \
 | |
|                     ? SOPT_SIZE_CMSG_PKTINFO_IPV6())
 | |
| 
 | |
| extern int setsockopt_ipv4_multicast_if(int sock, struct in_addr if_addr,
 | |
| 					ifindex_t ifindex);
 | |
| extern int setsockopt_ipv4_multicast(int sock, int optname,
 | |
| 				     struct in_addr if_addr,
 | |
| 				     unsigned int mcast_addr,
 | |
| 				     ifindex_t ifindex);
 | |
| extern int setsockopt_ipv4_multicast_loop(int sock, uint8_t val);
 | |
| 
 | |
| extern int setsockopt_ipv4_tos(int sock, int tos);
 | |
| 
 | |
| /* Ask for, and get, ifindex, by whatever method is supported. */
 | |
| extern int setsockopt_ifindex(int, int, ifindex_t);
 | |
| extern ifindex_t getsockopt_ifindex(int, struct msghdr *);
 | |
| 
 | |
| /* swab the fields in iph between the host order and system order expected
 | |
|  * for IP_HDRINCL.
 | |
|  */
 | |
| extern void sockopt_iphdrincl_swab_htosys(struct ip *iph);
 | |
| extern void sockopt_iphdrincl_swab_systoh(struct ip *iph);
 | |
| 
 | |
| extern int sockopt_tcp_rtt(int);
 | |
| 
 | |
| /*
 | |
|  * TCP MD5 signature option. This option allows TCP MD5 to be enabled on
 | |
|  * addresses.
 | |
|  *
 | |
|  * sock
 | |
|  *    Socket to enable option on.
 | |
|  *
 | |
|  * su
 | |
|  *    Sockunion specifying address to enable option on.
 | |
|  *
 | |
|  * password
 | |
|  *    MD5 auth password
 | |
|  */
 | |
| extern int sockopt_tcp_signature(int sock, union sockunion *su,
 | |
| 				 const char *password);
 | |
| 
 | |
| /*
 | |
|  * Extended TCP MD5 signature option. This option allows TCP MD5 to be enabled
 | |
|  * on prefixes.
 | |
|  *
 | |
|  * sock
 | |
|  *    Socket to enable option on.
 | |
|  *
 | |
|  * su
 | |
|  *    Sockunion specifying address (or prefix) to enable option on.
 | |
|  *
 | |
|  * prefixlen
 | |
|  *    0    - su is an address; fall back to non-extended mode
 | |
|  *    Else - su is a prefix; prefixlen is the mask length
 | |
|  *
 | |
|  * password
 | |
|  *    MD5 auth password
 | |
|  */
 | |
| extern int sockopt_tcp_signature_ext(int sock, union sockunion *su,
 | |
| 				     uint16_t prefixlen, const char *password);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /*_ZEBRA_SOCKOPT_H */
 |