diff options
author | Alexander Bluhm <bluhm@cvs.openbsd.org> | 2012-09-20 07:22:49 +0000 |
---|---|---|
committer | Alexander Bluhm <bluhm@cvs.openbsd.org> | 2012-09-20 07:22:49 +0000 |
commit | 01cd08d4901053796b54b570e024b6f04be7727f (patch) | |
tree | 03ec2b5587a691ed7413c22b7ea2ceaca7a443e5 | |
parent | 0787d49a4f46e21cd7ca21a8719d5c60be1b259f (diff) |
Bring back log_in6addr_scope() as ospf6ctl uses it.
Found by kettenis@ the hard way.
-rw-r--r-- | usr.sbin/ospf6d/log.c | 21 | ||||
-rw-r--r-- | usr.sbin/ospf6d/log.h | 3 |
2 files changed, 22 insertions, 2 deletions
diff --git a/usr.sbin/ospf6d/log.c b/usr.sbin/ospf6d/log.c index d010d18736d..db0ee9da7ac 100644 --- a/usr.sbin/ospf6d/log.c +++ b/usr.sbin/ospf6d/log.c @@ -1,4 +1,4 @@ -/* $OpenBSD: log.c,v 1.8 2012/09/19 19:15:27 bluhm Exp $ */ +/* $OpenBSD: log.c,v 1.9 2012/09/20 07:22:48 bluhm Exp $ */ /* * Copyright (c) 2006 Claudio Jeker <claudio@openbsd.org> @@ -189,6 +189,25 @@ log_in6addr(const struct in6_addr *addr) return (log_sockaddr(&sa_in6)); } +const char * +log_in6addr_scope(const struct in6_addr *addr, unsigned int ifindex) +{ + struct sockaddr_in6 sa_in6; + + bzero(&sa_in6, sizeof(sa_in6)); + sa_in6.sin6_len = sizeof(sa_in6); + sa_in6.sin6_family = AF_INET6; + memcpy(&sa_in6.sin6_addr, addr, sizeof(sa_in6.sin6_addr)); + + /* XXX thanks, IPv6 & KAME, for this ugliness... */ + if (IN6_IS_ADDR_LINKLOCAL(&sa_in6.sin6_addr) || + IN6_IS_ADDR_MC_LINKLOCAL(&sa_in6.sin6_addr)) { + sa_in6.sin6_scope_id = ifindex; + } + + return (log_sockaddr(&sa_in6)); +} + #define NUM_LOGS 4 const char * log_rtr_id(u_int32_t id) diff --git a/usr.sbin/ospf6d/log.h b/usr.sbin/ospf6d/log.h index d3cf6de77aa..09d6b5754c1 100644 --- a/usr.sbin/ospf6d/log.h +++ b/usr.sbin/ospf6d/log.h @@ -1,4 +1,4 @@ -/* $OpenBSD: log.h,v 1.6 2012/09/19 19:15:27 bluhm Exp $ */ +/* $OpenBSD: log.h,v 1.7 2012/09/20 07:22:48 bluhm Exp $ */ /* * Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org> @@ -32,6 +32,7 @@ void fatal(const char *) __dead; void fatalx(const char *) __dead; const char *log_in6addr(const struct in6_addr *); +const char *log_in6addr_scope(const struct in6_addr *, unsigned int); const char *log_rtr_id(u_int32_t); const char *log_sockaddr(void *); |