summaryrefslogtreecommitdiffstats
path: root/lib/sockunion.h
diff options
context:
space:
mode:
Diffstat (limited to 'lib/sockunion.h')
-rw-r--r--lib/sockunion.h103
1 files changed, 66 insertions, 37 deletions
diff --git a/lib/sockunion.h b/lib/sockunion.h
index 0ee2d63b..eeae72d5 100644
--- a/lib/sockunion.h
+++ b/lib/sockunion.h
@@ -17,12 +17,18 @@
* You should have received a copy of the GNU General Public License
* along with GNU Zebra; see the file COPYING. If not, write to the Free
* Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
- * 02111-1307, USA.
+ * 02111-1307, USA.
*/
#ifndef _ZEBRA_SOCKUNION_H
#define _ZEBRA_SOCKUNION_H
+#include "zebra.h"
+#include <stdbool.h>
+#include "symtab.h"
+#include "prefix.h"
+#include "memory.h"
+
#if 0
union sockunion {
struct sockinet {
@@ -38,7 +44,10 @@ union sockunion {
#define su_port su_si.si_port
#endif /* 0 */
-union sockunion
+typedef struct prefix* prefix ;
+
+typedef union sockunion* sockunion ;
+union sockunion
{
struct sockaddr sa;
struct sockaddr_in sin;
@@ -47,13 +56,6 @@ union sockunion
#endif /* HAVE_IPV6 */
};
-enum connect_result
-{
- connect_error,
- connect_success,
- connect_in_progress
-};
-
/* Default address family. */
#ifdef HAVE_IPV6
#define AF_INET_UNION AF_INET6
@@ -61,9 +63,21 @@ enum connect_result
#define AF_INET_UNION AF_INET
#endif
-/* Sockunion address string length. Same as INET6_ADDRSTRLEN. */
+/* Sockunion address string length. Accommodate either IPv4 or IPv6. */
#define SU_ADDRSTRLEN 46
+CONFIRM(SU_ADDRSTRLEN >= INET_ADDRSTRLEN) ;
+#if HAVE_IPV6
+CONFIRM(SU_ADDRSTRLEN >= INET6_ADDRSTRLEN) ;
+#endif
+
+/* Sockunion String Object */
+typedef struct sockunion_string sockunion_string_t ;
+struct sockunion_string
+{
+ char str[SU_ADDRSTRLEN] ;
+};
+
/* Macro to set link local index to the IPv6 address. For KAME IPv6
stack. */
#ifdef KAME
@@ -87,35 +101,47 @@ enum connect_result
#define sockunion_family(X) (X)->sa.sa_family
/* Prototypes. */
-extern int str2sockunion (const char *, union sockunion *);
-extern const char *sockunion2str (union sockunion *, char *, size_t);
-extern int sockunion_cmp (union sockunion *, union sockunion *);
-extern int sockunion_same (union sockunion *, union sockunion *);
-
-extern char *sockunion_su2str (union sockunion *su);
-extern union sockunion *sockunion_str2su (const char *str);
-extern struct in_addr sockunion_get_in_addr (union sockunion *su);
-extern int sockunion_accept (int sock, union sockunion *);
-extern int sockunion_stream_socket (union sockunion *);
-extern int sockopt_reuseaddr (int);
-extern int sockopt_reuseport (int);
-extern int sockunion_bind (int sock, union sockunion *,
- unsigned short, union sockunion *);
-extern int sockopt_ttl (int family, int sock, int ttl);
-extern int sockopt_minttl (int family, int sock, int minttl);
-extern int sockopt_cork (int sock, int onoff);
-extern int sockunion_socket (union sockunion *su);
-extern const char *inet_sutop (union sockunion *su, char *str);
-extern enum connect_result sockunion_connect (int fd, union sockunion *su,
- unsigned short port,
- unsigned int);
-extern union sockunion *sockunion_getsockname (int);
-extern union sockunion *sockunion_getpeername (int);
-extern union sockunion *sockunion_dup (union sockunion *);
-extern void sockunion_free (union sockunion *);
+extern sockunion sockunion_init_new(sockunion su, sa_family_t family) ;
+extern int sockunion_get_len(sockunion su) ;
+extern int sockunion_set_port(sockunion su, in_port_t port) ;
+extern int str2sockunion (const char * str, sockunion su);
+extern const char *sockunion2str (sockunion su, char* buf, size_t size);
+extern sockunion_string_t sutoa(sockunion su) ;
+extern int sockunion_cmp (sockunion su1, sockunion su2);
+extern int sockunion_same (sockunion su1, sockunion su2);
+
+extern char* sockunion_su2str (sockunion su, enum MTYPE type) ;
+extern sockunion sockunion_str2su (const char *str);
+extern struct in_addr sockunion_get_in_addr (sockunion su);
+extern int sockunion_accept (int sock_fd, sockunion su);
+extern int sockunion_stream_socket (sockunion su);
+extern int sockunion_bind (int sock_fd, sockunion su,
+ unsigned short port, bool any) ;
+extern int sockunion_socket (sockunion su, int type, int protocol) ;
+extern int sockunion_connect (int sock_fd, sockunion su,
+ unsigned short port, unsigned int ifindex) ;
+extern int sockunion_listen(int sock_fd, int backlog) ;
+
+extern int sockunion_getsockfamily(int sock_fd) ;
+extern int sockunion_getprotofamily(int sock_fd) ;
+extern int sockunion_getsockname (int sock_fd, sockunion su);
+extern int sockunion_getpeername (int sock_fd, sockunion su);
+extern void sockunion_unmap_ipv4 (sockunion su) ;
+extern void sockunion_map_ipv4 (sockunion su) ;
+
+extern sockunion sockunion_dup (sockunion src);
+extern void sockunion_copy (sockunion dst, sockunion src) ;
+extern void sockunion_free (sockunion su);
+
+extern sockunion sockunion_new_prefix(sockunion su, prefix p) ;
+extern sockunion sockunion_new_sockaddr(sockunion su, struct sockaddr* sa) ;
+extern void sockunion_unset(sockunion* p_su) ;
+extern void sockunion_set(sockunion* p_dst, sockunion su) ;
+extern void sockunion_set_dup(sockunion* p_dst, sockunion su) ;
+extern void sockunion_set_mov(sockunion* p_dst, sockunion* p_src) ;
#ifndef HAVE_INET_NTOP
-extern const char * inet_ntop (int family, const void *addrptr,
+extern const char * inet_ntop (int family, const void *addrptr,
char *strptr, size_t len);
#endif /* HAVE_INET_NTOP */
@@ -127,4 +153,7 @@ extern int inet_pton (int family, const char *strptr, void *addrptr);
extern int inet_aton (const char *cp, struct in_addr *inaddr);
#endif
+extern void
+sockunion_symbol_hash(symbol_hash p_hash, const void* name) ;
+
#endif /* _ZEBRA_SOCKUNION_H */