diff options
-rw-r--r-- | src/host/virt_phy/src/shared/osmo_mcast_sock.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/host/virt_phy/src/shared/osmo_mcast_sock.c b/src/host/virt_phy/src/shared/osmo_mcast_sock.c index acc6bcb1..ff81063a 100644 --- a/src/host/virt_phy/src/shared/osmo_mcast_sock.c +++ b/src/host/virt_phy/src/shared/osmo_mcast_sock.c @@ -52,7 +52,7 @@ struct mcast_client_sock *mcast_client_sock_setup( struct mcast_client_sock); struct sockaddr_in *rx_sock_conf = talloc_zero(NULL, struct sockaddr_in); - int rc, reuseaddr = 1, loopback = 1; + int rc, reuseaddr = 1, loopback = 1, all = 0; client_sock->osmo_fd = talloc_zero(ctx, struct osmo_fd); client_sock->mcast_group = talloc_zero(ctx, struct ip_mreq); @@ -107,6 +107,14 @@ struct mcast_client_sock *mcast_client_sock_setup( return NULL; } + // this option will set the delivery option so that only packages are received + // from sockets we are bound to via IP_ADD_MEMBERSHIP + if (setsockopt(client_sock->osmo_fd->fd, IPPROTO_IP, + IP_MULTICAST_ALL, &all, sizeof(all)) < 0) { + perror("Failed to modify delivery policy to explicitly joined.\n"); + return NULL; + } + // configure and register the osmocom filedescriptor client_sock->osmo_fd->cb = fd_rx_cb; client_sock->osmo_fd->when = BSC_FD_READ; |