diff options
author | Josh Blum <josh@joshknows.com> | 2010-10-22 11:24:37 -0700 |
---|---|---|
committer | Josh Blum <josh@joshknows.com> | 2010-10-22 11:24:37 -0700 |
commit | 2ce71ded9dada93ade6f960aac0bd4c25e47456a (patch) | |
tree | 9ab11b64556e0183ce3f1911d97e75e7fcce2e86 /firmware/microblaze/lib/net_common.c | |
parent | 2628d78e0d0348001cb8428c8064cd1e3179afc8 (diff) | |
parent | 8a695c06848dfd254d372e661aa00c2c8d6184a1 (diff) | |
download | uhd-2ce71ded9dada93ade6f960aac0bd4c25e47456a.tar.gz uhd-2ce71ded9dada93ade6f960aac0bd4c25e47456a.tar.bz2 uhd-2ce71ded9dada93ade6f960aac0bd4c25e47456a.zip |
Merge branch 'garp' into flow_ctrl
Diffstat (limited to 'firmware/microblaze/lib/net_common.c')
-rw-r--r-- | firmware/microblaze/lib/net_common.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/firmware/microblaze/lib/net_common.c b/firmware/microblaze/lib/net_common.c index 0efb26639..0a085db3a 100644 --- a/firmware/microblaze/lib/net_common.c +++ b/firmware/microblaze/lib/net_common.c @@ -360,6 +360,22 @@ send_arp_reply(struct arp_eth_ipv4 *req, eth_mac_addr_t our_mac) send_pkt(t, ETHERTYPE_ARP, &reply, sizeof(reply), 0, 0, 0, 0); } +void send_gratuitous_arp(void){ + struct arp_eth_ipv4 req _AL4; + req.ar_hrd = ARPHRD_ETHER; + req.ar_pro = ETHERTYPE_IPV4; + req.ar_hln = sizeof(eth_mac_addr_t); + req.ar_pln = sizeof(struct ip_addr); + req.ar_op = ARPOP_REQUEST; + memcpy(req.ar_sha, ethernet_mac_addr(), sizeof(eth_mac_addr_t)); + memcpy(req.ar_sip, get_ip_addr(), sizeof(struct ip_addr)); + memset(req.ar_tha, 0x00, sizeof(eth_mac_addr_t)); + memcpy(req.ar_tip, get_ip_addr(), sizeof(struct ip_addr)); + + //send the request with a broadcast ethernet mac address + eth_mac_addr_t t; memset(&t, 0xff, sizeof(t)); + send_pkt(t, ETHERTYPE_ARP, &req, sizeof(req), 0, 0, 0, 0); +} static void handle_arp_packet(struct arp_eth_ipv4 *p, size_t size) |