X-Git-Url: http://git.sameswireless.fr/l2tpns.git/blobdiff_plain/c7983582eaeac8f1e2a66cbff6bdb20aeb58ad8e..6f2dddc914f438bd0d0cfcb341f1066f68e92a05:/arp.c?ds=sidebyside diff --git a/arp.c b/arp.c index 4434364..5ffd1a4 100644 --- a/arp.c +++ b/arp.c @@ -1,6 +1,6 @@ // L2TPNS: arp -char const *cvs_id_arp = "$Id: arp.c,v 1.4 2004/07/08 16:19:09 bodea Exp $"; +char const *cvs_id_arp = "$Id: arp.c,v 1.7 2005/07/31 10:04:09 bodea Exp $"; #include #include @@ -18,18 +18,18 @@ struct arp_buf { /* Data bit - variably sized, so not present in |struct arphdr| */ unsigned char ar_sha[ETH_ALEN]; /* Sender hardware address */ - ipt ar_sip; /* Sender IP address. */ + in_addr_t ar_sip; /* Sender IP address. */ unsigned char ar_tha[ETH_ALEN]; /* Target hardware address */ - ipt ar_tip; /* Target ip */ + in_addr_t ar_tip; /* Target ip */ } __attribute__((packed)); -void sendarp(int ifr_idx, const unsigned char* mac, ipt ip) +void sendarp(int ifr_idx, const unsigned char* mac, in_addr_t ip) { int fd; struct sockaddr_ll sll; struct arp_buf buf; - CSTAT(call_sendarp); + CSTAT(sendarp); STAT(arp_sent); /* Ethernet */ @@ -55,7 +55,7 @@ void sendarp(int ifr_idx, const unsigned char* mac, ipt ip) memset(&sll, 0, sizeof(sll)); sll.sll_family = AF_PACKET; - strncpy(sll.sll_addr, mac, sizeof(sll.sll_addr) - 1); + memcpy(sll.sll_addr, mac, sizeof(sll.sll_addr) - 1); sll.sll_halen = ETH_ALEN; sll.sll_ifindex = ifr_idx;