From: Russell Leighton <russ@elegant-software.com>
To: David Stevens <dlstevens@us.ibm.com>
Cc: Andrew Morton <akpm@osdl.org>, netdev@oss.sgi.com
Subject: Re: Fw: F_SETSIG broken/changed in 2.6 for UDP and TCP sockets?
Date: Tue, 01 Jun 2004 18:48:28 -0400 [thread overview]
Message-ID: <40BD07BC.8030302@elegant-software.com> (raw)
In-Reply-To: <OFAD1DE5B4.1A829EE7-ON88256EA6.006EE314-88256EA6.006F8B71@us.ibm.com>
[-- Attachment #1: Type: text/plain, Size: 4110 bytes --]
Thanks for the suggestion.
I tried using the interface itself and INADDR_ANY...the signals are not
being received under 2.6 (FedoraCore2) UNLESS tcpdump is running...note
this works fine under 2.4.
Below is the code fragment that sets up the socket (the previous email
had the code fragment that sets up the posix rt signals on the fd), any
help would be greatly appreciated:
/* mc_fd */
{
/* make it */
if ( (h->state.mc_fd = socket(AF_INET, SOCK_DGRAM, 0)) == -1 ) {
aw_log(h->handler_header.logger, AW_ERROR_LOG_LEVEL, "mcrxhandler
cannot create socket: %s", strerror(errno));
goto error;
}
/* set it to nonblocking so that this can be async */
if ( fcntl(h->state.mc_fd, F_SETFL, O_NONBLOCK) == -1) {
aw_log(h->handler_header.logger, AW_ERROR_LOG_LEVEL, "mcrxhandler
cannot set socket nonblocking: %s", strerror(errno));
goto error;
}
/* set the mc interface */
if ( setsockopt(h->state.mc_fd, IPPROTO_IP, IP_MULTICAST_IF,
&(h->mcast_if_addr), sizeof(h->mcast_if_addr)) < 0 ) {
u_int8_t
*ip = (u_int8_t *)&(h->mcast_if_addr);
aw_log(h->handler_header.logger, AW_ERROR_LOG_LEVEL,
"mcrxhandler cannot set socket IP_MULTICAST_IF for %u.%u.%u.%u:
%s",
ip[0],ip[1],ip[2],ip[4],
strerror(errno));
goto error;
}
{ /* debugging where packets are going when you have many interfaces
is a pain, you want to log this! */
u_int8_t
*ip = (u_int8_t *)&(h->mcast_if_addr);
aw_log(h->handler_header.logger, AW_INFO_LOG_LEVEL, "mcrxhandler
running multicast on interface %u.%u.%u.%u",
ip[0],ip[1],ip[2],ip[3]);
}
/* use setsockopt() to request that the kernel join a multicast group */
{
struct ip_mreq
mreq;
/* set up */
memset(&mreq, 0 , sizeof(mreq));
mreq.imr_multiaddr.s_addr= h->mcast_grp_addr.sin_addr.s_addr;
mreq.imr_interface.s_addr= h->mcast_if_addr.s_addr;
if (setsockopt(h->state.mc_fd, IPPROTO_IP,IP_ADD_MEMBERSHIP, (char
*)&mreq, sizeof(mreq)) < 0) {
aw_log(h->handler_header.logger, AW_ERROR_LOG_LEVEL,
"mcrxhandler cannot set socket IPPROTO_IP,IP_ADD_MEMBERSHIP:
%s", strerror(errno));
goto error;
}
}
/* so we can have many processes listening to mcast */
{
int32_t
itmp = 1;
if ( setsockopt(h->state.mc_fd, SOL_SOCKET, SO_REUSEADDR , (char
*)&itmp, sizeof(itmp)) < 0 ) {
aw_log(h->handler_header.logger, AW_ERROR_LOG_LEVEL, "mcrxhandler
cannot set socket SO_REUSEADDR: %s", strerror(errno));
}
}
/* bind to receive messages */
if (bind(h->state.mc_fd, (struct sockaddr *)&(h->mcast_grp_addr),
sizeof(h->mcast_grp_addr)) < 0) {
aw_log(h->handler_header.logger, AW_ERROR_LOG_LEVEL, "mcrxhandler
cannot bind to multicast socket", strerror(errno));
goto error ;
}
/* add callback to handle packets on mc_fd */
aw_add_handler_fdcallback(mon, (aw_handler_t *)h, h->state.mc_fd,
do_read);
} /* end mc_fd */
David Stevens wrote:
>>In the udp case, I when I listen for multicast packets my app only
>>receives them when I am running a tcpdump (bizarre!).
>>
>>
>
>Russ,
> This piece (which I expect has nothing to do with the other
>problems you mentioned) sounds like you haven't joined the groups on
>the interface on which you're receiving the multicast packets.
>"tcpdump" will place the interface in "promiscuous mode" which will
>receive all packets, and ordinary packet delivery will allow
>the application to receive them, even if you haven't joined the group
>on the relevant interface.
> To verify if the group joins is broken, you can look at
>/proc/net/igmp. If the groups you're joining are not listed on the
>interface you want, the program isn't joining the groups correctly.
>Group membership is per-interface, so joining a group on one interface
>does not join it on another.
> Feel free to contact me if you need some help debugging the
>multicast problem.
>
> +-DLS
>
>
>
>
>
[-- Attachment #2: Type: text/html, Size: 6117 bytes --]
next prev parent reply other threads:[~2004-06-01 22:48 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-05-31 22:18 Fw: F_SETSIG broken/changed in 2.6 for UDP and TCP sockets? Andrew Morton
2004-06-01 20:19 ` David Stevens
2004-06-01 22:48 ` Russell Leighton [this message]
2004-06-01 23:08 ` Russell Leighton
2004-06-04 2:24 ` Russell Leighton
2004-06-05 15:14 ` Russell Leighton
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=40BD07BC.8030302@elegant-software.com \
--to=russ@elegant-software.com \
--cc=akpm@osdl.org \
--cc=dlstevens@us.ibm.com \
--cc=netdev@oss.sgi.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).