summaryrefslogtreecommitdiff
path: root/sys/netinet6/in6.c
diff options
context:
space:
mode:
authorJun-ichiro itojun Hagino <itojun@cvs.openbsd.org>2002-06-07 15:00:56 +0000
committerJun-ichiro itojun Hagino <itojun@cvs.openbsd.org>2002-06-07 15:00:56 +0000
commit4cefecc27da2bbc13cb635845a388f06747d3fa2 (patch)
tree18e51e3896e040b91ee59fd5b46098ef8078033d /sys/netinet6/in6.c
parent8148a94b09e3f2e070d594d4241a3dc70a098403 (diff)
style
Diffstat (limited to 'sys/netinet6/in6.c')
-rw-r--r--sys/netinet6/in6.c35
1 files changed, 34 insertions, 1 deletions
diff --git a/sys/netinet6/in6.c b/sys/netinet6/in6.c
index 4fa5893cf2c..ad600cb25b9 100644
--- a/sys/netinet6/in6.c
+++ b/sys/netinet6/in6.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: in6.c,v 1.38 2002/06/07 04:18:56 itojun Exp $ */
+/* $OpenBSD: in6.c,v 1.39 2002/06/07 15:00:54 itojun Exp $ */
/* $KAME: in6.c,v 1.198 2001/07/18 09:12:38 itojun Exp $ */
/*
@@ -1379,6 +1379,39 @@ in6_delmulti(in6m)
splx(s);
}
+struct in6_multi_mship *
+in6_joingroup(ifp, addr, errorp)
+ struct ifnet *ifp;
+ struct in6_addr *addr;
+ int *errorp;
+{
+ struct in6_multi_mship *imm;
+
+ imm = malloc(sizeof(*imm), M_IPMADDR, M_NOWAIT);
+ if (!imm) {
+ *errorp = ENOBUFS;
+ return NULL;
+ }
+ imm->i6mm_maddr = in6_addmulti(addr, ifp, errorp);
+ if (!imm->i6mm_maddr) {
+ /* *errorp is alrady set */
+ free(imm, M_IPMADDR);
+ return NULL;
+ }
+ return imm;
+}
+
+int
+in6_leavegroup(imm)
+ struct in6_multi_mship *imm;
+{
+
+ if (imm->i6mm_maddr)
+ in6_delmulti(imm->i6mm_maddr);
+ free(imm, M_IPMADDR);
+ return 0;
+}
+
/*
* Find an IPv6 interface link-local address specific to an interface.
*/