Date: Thu, 12 Aug 2004 11:59:28 +0400 From: Gleb Smirnoff <glebius@freebsd.org> To: current@freebsd.org Subject: if_index in struct ifnet broken in recent CURRENT Message-ID: <20040812075928.GA21205@cell.sick.ru> In-Reply-To: <20040812075053.GA21129@cell.sick.ru> References: <20040812075053.GA21129@cell.sick.ru>
next in thread | previous in thread | raw e-mail | index | archive | help
Hmm, some more information: actually if_index is broken not only in in mbuf packet headers. This code with different addresses: bzero((caddr_t)&ro, sizeof(ro)); sin = (struct sockaddr_in *)&ro.ro_dst; sin->sin_len = sizeof(*sin); sin->sin_family = AF_INET; sin->sin_addr = \\some address\\; rtalloc_ign(&ro, RTF_CLONING); if (ro.ro_rt != NULL) { struct rtentry *rt = ro.ro_rt; printf("rt idx %d, name %s\n", rt->rt_ifp->if_index, rt->rt_ifp->if_xname); produces rt idx 0, name fxp0 rt idx 0, name lo0 On Thu, Aug 12, 2004 at 11:50:53AM +0400, Gleb Smirnoff wrote: T> I can see this at least in fxp driver: if I capture packets using T> ng_ether(4), and check interface name like this T> T> printf("idx %d, name %s\n", T> (*m)->m_pkthdr.rcvif->if_index, T> (*m)->m_pkthdr.rcvif->if_xname); T> I get on console: T> T> idx 0, name fxp0 T> T> Really fxp's index is 1 (AFAIK if_index must be > 0), I have checked this T> using if_nametoindex() from userland. -- Totus tuus, Glebius. GLEBIUS-RIPN GLEB-RIPE
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20040812075928.GA21205>