📄 ipaddr.c
字号:
/* * IP MIB group implementation - ip.c * */#include <config.h>#if defined(IFNET_NEEDS_KERNEL) && !defined(_KERNEL)#define _KERNEL 1#define _I_DEFINED_KERNEL#endif#if HAVE_SYS_PARAM_H#include <sys/param.h>#endif#if HAVE_SYS_SOCKET_H#include <sys/socket.h>#endif#if HAVE_STRING_H#include <string.h>#else#include <strings.h>#endif#include <sys/types.h>#if HAVE_WINSOCK_H#include <winsock.h>#endif#if HAVE_SYS_SYSCTL_H#ifdef _I_DEFINED_KERNEL#undef _KERNEL#endif#include <sys/sysctl.h>#ifdef _I_DEFINED_KERNEL#define _KERNEL 1#endif#endif#if HAVE_SYS_SYSMP_H#include <sys/sysmp.h>#endif#if HAVE_SYS_TCPIPSTATS_H#include <sys/tcpipstats.h>#endif#if HAVE_NETINET_IN_H#include <netinet/in.h>#endif#if HAVE_NET_IF_H#include <net/if.h>#endif#if HAVE_NET_IF_VAR_H#include <net/if_var.h>#endif#ifdef _I_DEFINED_KERNEL#undef _KERNEL#endif#if HAVE_NETINET_IN_SYSTM_H#include <netinet/in_systm.h>#endif#if HAVE_SYS_HASHING_H#include <sys/hashing.h>#endif#if HAVE_NETINET_IN_VAR_H#include <netinet/in_var.h>#endif#if HAVE_NETINET_IP_H#include <netinet/ip.h>#endif#if HAVE_NETINET_IP_VAR_H#include <netinet/ip_var.h>#endif#if HAVE_INET_MIB2_H#include <inet/mib2.h>#endif#if HAVE_SYS_STREAM_H#include <sys/stream.h>#endif#if HAVE_NET_ROUTE_H#include <net/route.h>#endif#if HAVE_SYSLOG_H#include <syslog.h>#endif#ifdef solaris2#include "kernel_sunos5.h"#else#include "kernel.h"#endif#include "mibincl.h"#include "system.h"#include "auto_nlist.h"#if defined(MIB_IPCOUNTER_SYMBOL) || defined(hpux11)#include <sys/mib.h>#include <netinet/mib_kern.h>#endif /* MIB_IPCOUNTER_SYMBOL || hpux11 */#include "ip.h"#include "interfaces.h"#include "sysORTable.h"#ifdef cygwin#define WIN32#include <windows.h>#endif /********************* * * Kernel & interface information, * and internal forward declarations * *********************/ /********************* * * Initialisation & common implementation functions * *********************/ /********************* * * System specific implementation functions * *********************/#ifndef WIN32#if !defined(CAN_USE_SYSCTL) || !defined(IPCTL_STATS)#ifndef solaris2#if defined(freebsd2) || defined(hpux11)static void Address_Scan_Init (void);#ifdef freebsd2static int Address_Scan_Next (short *, struct in_ifaddr *);#elsestatic int Address_Scan_Next (short *, mib_ipAdEnt *);#endif#endif/* var_ipAddrEntry(... Arguments: vp IN - pointer to variable entry that points here name IN/OUT - IN/name requested, OUT/name found length IN/OUT - length of IN/OUT oid's exact IN - TRUE if an exact match was requested var_len OUT - length of variable or 0 if function returned write_method */u_char *var_ipAddrEntry(struct variable *vp, oid *name, size_t *length, int exact, size_t *var_len, WriteMethod **write_method){ /* * object identifier is of form: * 1.3.6.1.2.1.4.20.1.?.A.B.C.D, where A.B.C.D is IP address. * IPADDR starts at offset 10. */ oid lowest[14]; oid current[14], *op; u_char *cp; int lowinterface=0; short interface;#ifdef hpux11 static mib_ipAdEnt in_ifaddr, lowin_ifaddr;#else static struct in_ifaddr in_ifaddr;#if !defined(linux) && !defined(sunV3) static struct in_ifaddr lowin_ifaddr;#else static struct ifnet lowin_ifnet;#endif static struct ifnet ifnet;#endif /* hpux11 */ /* fill in object part of name for current (less sizeof instance part) */ memcpy( (char *)current,(char *)vp->name, (int)vp->namelen * sizeof(oid));#if !defined(freebsd2) && !defined(hpux11) Interface_Scan_Init();#else Address_Scan_Init();#endif for (;;) {#if !defined(freebsd2) && !defined(hpux11) if (Interface_Scan_Next(&interface, NULL, &ifnet, &in_ifaddr) == 0) break;#ifdef STRUCT_IFNET_HAS_IF_ADDRLIST if ( ifnet.if_addrlist == 0 ) continue; /* No address found for interface */#endif#else /* !freebsd2 && !hpux11 */ if (Address_Scan_Next(&interface, &in_ifaddr) == 0) break;#endif /* !freebsd2 && !hpux11 */#ifdef hpux11 cp = (u_char *)&in_ifaddr.Addr;#elif defined(linux) || defined(sunV3) cp = (u_char *)&(((struct sockaddr_in *) &(ifnet.if_addr))->sin_addr.s_addr);#else cp = (u_char *)&(((struct sockaddr_in *) &(in_ifaddr.ia_addr))->sin_addr.s_addr);#endif op = current + 10; *op++ = *cp++; *op++ = *cp++; *op++ = *cp++; *op++ = *cp++; if (exact){ if (snmp_oid_compare(current, 14, name, *length) == 0){ memcpy( (char *)lowest,(char *)current, 14 * sizeof(oid)); lowinterface = interface;#if defined(linux) || defined(sunV3) lowin_ifnet = ifnet;#else lowin_ifaddr = in_ifaddr;#endif break; /* no need to search further */ } } else { if ((snmp_oid_compare(current, 14, name, *length) > 0) && (!lowinterface || (snmp_oid_compare(current, 14, lowest, 14) < 0))){ /* * if new one is greater than input and closer to input than * previous lowest, save this one as the "next" one. */ lowinterface = interface;#if defined(linux) || defined(sunV3) lowin_ifnet = ifnet;#else lowin_ifaddr = in_ifaddr;#endif memcpy( (char *)lowest,(char *)current, 14 * sizeof(oid)); } } } if (!lowinterface) return(NULL); memcpy( (char *)name,(char *)lowest, 14 * sizeof(oid)); *length = 14; *write_method = 0; *var_len = sizeof(long_return); switch(vp->magic){ case IPADADDR:#ifdef hpux11 long_return = lowin_ifaddr.Addr; return(u_char *) &long_return;#elif defined(linux) || defined(sunV3) return(u_char *) &((struct sockaddr_in *) &lowin_ifnet.if_addr)->sin_addr.s_addr;#else return(u_char *) &((struct sockaddr_in *) &lowin_ifaddr.ia_addr)->sin_addr.s_addr;#endif case IPADIFINDEX: long_return = lowinterface; return(u_char *) &long_return; case IPADNETMASK:#ifdef hpux11 long_return = lowin_ifaddr.NetMask; return(u_char *) &long_return;#elif defined(linux) return (u_char *)&((struct sockaddr_in *)&lowin_ifnet.ia_subnetmask)->sin_addr.s_addr;#elif !defined(sunV3) long_return = lowin_ifaddr.ia_subnetmask; return(u_char *) &long_return;#endif case IPADBCASTADDR:#ifdef hpux11 long_return = lowin_ifaddr.BcastAddr;#elif defined(linux) || defined(sunV3) long_return = ntohl(((struct sockaddr_in *) &lowin_ifnet.ifu_broadaddr)->sin_addr.s_addr) & 1;#else long_return = ntohl(((struct sockaddr_in *) &lowin_ifaddr.ia_broadaddr)->sin_addr.s_addr) & 1;#endif return(u_char *) &long_return; case IPADREASMMAX:#ifdef hpux11 long_return = lowin_ifaddr.ReasmMaxSize; return(u_char *) &long_return;#elif defined(NO_DUMMY_VALUES) return NULL;#else long_return = -1; return(u_char *) &long_return;#endif default: DEBUGMSGTL(("snmpd", "unknown sub-id %d in var_ipAddrEntry\n", vp->magic)); } return NULL;}#ifdef freebsd2static struct in_ifaddr *in_ifaddraddr;static voidAddress_Scan_Init (void){ auto_nlist(IFADDR_SYMBOL, (char *)&in_ifaddraddr, sizeof(in_ifaddraddr));}/* NB: Index is the number of the corresponding interface, not of the address */static int Address_Scan_Next(Index, Retin_ifaddr)short *Index;struct in_ifaddr *Retin_ifaddr;{ struct in_ifaddr in_ifaddr; struct ifnet ifnet,*ifnetaddr; /* NOTA: same name as another one */ short iindex=1; while (in_ifaddraddr) { /* * Get the "in_ifaddr" structure */ klookup((unsigned long)in_ifaddraddr, (char *)&in_ifaddr, sizeof in_ifaddr); in_ifaddraddr = in_ifaddr.ia_next; if (Retin_ifaddr) *Retin_ifaddr = in_ifaddr; /* * Now, more difficult, find the index of the interface to which * this address belongs */ auto_nlist(IFNET_SYMBOL, (char *)&ifnetaddr, sizeof(ifnetaddr)); while (ifnetaddr && ifnetaddr != in_ifaddr.ia_ifp) { klookup((unsigned long)ifnetaddr, (char *)&ifnet, sizeof ifnet); ifnetaddr = ifnet.if_next; iindex++; } /* XXX - might not find it? */ if (Index) *Index = iindex; return(1); /* DONE */ } return(0); /* EOF */}#elif defined(hpux11)static int iptab_size, iptab_current;static mib_ipAdEnt *ip = (mib_ipAdEnt *)0;static voidAddress_Scan_Init (void){ int fd; struct nmparms p; int val; unsigned int ulen; int ret; if (ip) free(ip); ip = (mib_ipAdEnt *)0; iptab_size = 0; if ((fd = open_mib("/dev/ip", O_RDONLY, 0, NM_ASYNC_OFF)) >= 0) { p.objid = ID_ipAddrNumEnt; p.buffer = (void *)&val; ulen = sizeof(int); p.len = &ulen; if ((ret = get_mib_info(fd, &p)) == 0) iptab_size = val; if (iptab_size > 0) { ulen = (unsigned)iptab_size * sizeof(mib_ipAdEnt); ip = (mib_ipAdEnt *)malloc(ulen); p.objid = ID_ipAddrTable; p.buffer = (void *)ip; p.len = &ulen; if ((ret = get_mib_info(fd, &p)) < 0) iptab_size = 0; } close_mib(fd); } iptab_current = 0;}/* NB: Index is the number of the corresponding interface, not of the address */static intAddress_Scan_Next(Index, Retin_ifaddr) short *Index; mib_ipAdEnt *Retin_ifaddr;{ if (iptab_current < iptab_size) { /* copy values */ *Index = ip[iptab_current].IfIndex; *Retin_ifaddr = ip[iptab_current]; /* increment to point to next entry */ iptab_current++; /* return success */ return (1); } /* return done */ return (0);}#endif /* hpux11 */#else /* solaris2 */static intIP_Cmp(void *addr, void *ep){ if (((mib2_ipAddrEntry_t *)ep)->ipAdEntAddr == *(IpAddress *)addr) return (0); else return (1);}u_char *var_ipAddrEntry(struct variable *vp,
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -