xref: /minix3/minix/lib/liblwip/dist/src/include/lwip/etharp.h (revision 5d5fbe79c1b60734f34c69330aec5496644e8651)
1*5d5fbe79SDavid van Moolenbroek /**
2*5d5fbe79SDavid van Moolenbroek  * @file
3*5d5fbe79SDavid van Moolenbroek  * Ethernet output function - handles OUTGOING ethernet level traffic, implements
4*5d5fbe79SDavid van Moolenbroek  * ARP resolving.
5*5d5fbe79SDavid van Moolenbroek  * To be used in most low-level netif implementations
6*5d5fbe79SDavid van Moolenbroek  */
7*5d5fbe79SDavid van Moolenbroek 
8*5d5fbe79SDavid van Moolenbroek /*
9*5d5fbe79SDavid van Moolenbroek  * Copyright (c) 2001-2003 Swedish Institute of Computer Science.
10*5d5fbe79SDavid van Moolenbroek  * Copyright (c) 2003-2004 Leon Woestenberg <leon.woestenberg@axon.tv>
11*5d5fbe79SDavid van Moolenbroek  * Copyright (c) 2003-2004 Axon Digital Design B.V., The Netherlands.
12*5d5fbe79SDavid van Moolenbroek  * All rights reserved.
13*5d5fbe79SDavid van Moolenbroek  *
14*5d5fbe79SDavid van Moolenbroek  * Redistribution and use in source and binary forms, with or without modification,
15*5d5fbe79SDavid van Moolenbroek  * are permitted provided that the following conditions are met:
16*5d5fbe79SDavid van Moolenbroek  *
17*5d5fbe79SDavid van Moolenbroek  * 1. Redistributions of source code must retain the above copyright notice,
18*5d5fbe79SDavid van Moolenbroek  *    this list of conditions and the following disclaimer.
19*5d5fbe79SDavid van Moolenbroek  * 2. Redistributions in binary form must reproduce the above copyright notice,
20*5d5fbe79SDavid van Moolenbroek  *    this list of conditions and the following disclaimer in the documentation
21*5d5fbe79SDavid van Moolenbroek  *    and/or other materials provided with the distribution.
22*5d5fbe79SDavid van Moolenbroek  * 3. The name of the author may not be used to endorse or promote products
23*5d5fbe79SDavid van Moolenbroek  *    derived from this software without specific prior written permission.
24*5d5fbe79SDavid van Moolenbroek  *
25*5d5fbe79SDavid van Moolenbroek  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
26*5d5fbe79SDavid van Moolenbroek  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
27*5d5fbe79SDavid van Moolenbroek  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
28*5d5fbe79SDavid van Moolenbroek  * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
29*5d5fbe79SDavid van Moolenbroek  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
30*5d5fbe79SDavid van Moolenbroek  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
31*5d5fbe79SDavid van Moolenbroek  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
32*5d5fbe79SDavid van Moolenbroek  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
33*5d5fbe79SDavid van Moolenbroek  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
34*5d5fbe79SDavid van Moolenbroek  * OF SUCH DAMAGE.
35*5d5fbe79SDavid van Moolenbroek  *
36*5d5fbe79SDavid van Moolenbroek  * This file is part of the lwIP TCP/IP stack.
37*5d5fbe79SDavid van Moolenbroek  *
38*5d5fbe79SDavid van Moolenbroek  * Author: Adam Dunkels <adam@sics.se>
39*5d5fbe79SDavid van Moolenbroek  *
40*5d5fbe79SDavid van Moolenbroek  */
41*5d5fbe79SDavid van Moolenbroek 
42*5d5fbe79SDavid van Moolenbroek #ifndef LWIP_HDR_NETIF_ETHARP_H
43*5d5fbe79SDavid van Moolenbroek #define LWIP_HDR_NETIF_ETHARP_H
44*5d5fbe79SDavid van Moolenbroek 
45*5d5fbe79SDavid van Moolenbroek #include "lwip/opt.h"
46*5d5fbe79SDavid van Moolenbroek 
47*5d5fbe79SDavid van Moolenbroek #if LWIP_ARP || LWIP_ETHERNET /* don't build if not configured for use in lwipopts.h */
48*5d5fbe79SDavid van Moolenbroek 
49*5d5fbe79SDavid van Moolenbroek #include "lwip/pbuf.h"
50*5d5fbe79SDavid van Moolenbroek #include "lwip/ip4_addr.h"
51*5d5fbe79SDavid van Moolenbroek #include "lwip/netif.h"
52*5d5fbe79SDavid van Moolenbroek #include "lwip/ip4.h"
53*5d5fbe79SDavid van Moolenbroek #include "lwip/prot/ethernet.h"
54*5d5fbe79SDavid van Moolenbroek 
55*5d5fbe79SDavid van Moolenbroek #ifdef __cplusplus
56*5d5fbe79SDavid van Moolenbroek extern "C" {
57*5d5fbe79SDavid van Moolenbroek #endif
58*5d5fbe79SDavid van Moolenbroek 
59*5d5fbe79SDavid van Moolenbroek #if LWIP_IPV4 && LWIP_ARP /* don't build if not configured for use in lwipopts.h */
60*5d5fbe79SDavid van Moolenbroek 
61*5d5fbe79SDavid van Moolenbroek #include "lwip/prot/etharp.h"
62*5d5fbe79SDavid van Moolenbroek 
63*5d5fbe79SDavid van Moolenbroek /** 1 seconds period */
64*5d5fbe79SDavid van Moolenbroek #define ARP_TMR_INTERVAL 1000
65*5d5fbe79SDavid van Moolenbroek 
66*5d5fbe79SDavid van Moolenbroek #if ARP_QUEUEING
67*5d5fbe79SDavid van Moolenbroek /** struct for queueing outgoing packets for unknown address
68*5d5fbe79SDavid van Moolenbroek   * defined here to be accessed by memp.h
69*5d5fbe79SDavid van Moolenbroek   */
70*5d5fbe79SDavid van Moolenbroek struct etharp_q_entry {
71*5d5fbe79SDavid van Moolenbroek   struct etharp_q_entry *next;
72*5d5fbe79SDavid van Moolenbroek   struct pbuf *p;
73*5d5fbe79SDavid van Moolenbroek };
74*5d5fbe79SDavid van Moolenbroek #endif /* ARP_QUEUEING */
75*5d5fbe79SDavid van Moolenbroek 
76*5d5fbe79SDavid van Moolenbroek #define etharp_init() /* Compatibility define, no init needed. */
77*5d5fbe79SDavid van Moolenbroek void etharp_tmr(void);
78*5d5fbe79SDavid van Moolenbroek s8_t etharp_find_addr(struct netif *netif, const ip4_addr_t *ipaddr,
79*5d5fbe79SDavid van Moolenbroek          struct eth_addr **eth_ret, const ip4_addr_t **ip_ret);
80*5d5fbe79SDavid van Moolenbroek u8_t etharp_get_entry(u8_t i, ip4_addr_t **ipaddr, struct netif **netif, struct eth_addr **eth_ret);
81*5d5fbe79SDavid van Moolenbroek err_t etharp_output(struct netif *netif, struct pbuf *q, const ip4_addr_t *ipaddr);
82*5d5fbe79SDavid van Moolenbroek err_t etharp_query(struct netif *netif, const ip4_addr_t *ipaddr, struct pbuf *q);
83*5d5fbe79SDavid van Moolenbroek err_t etharp_request(struct netif *netif, const ip4_addr_t *ipaddr);
84*5d5fbe79SDavid van Moolenbroek /** For Ethernet network interfaces, we might want to send "gratuitous ARP";
85*5d5fbe79SDavid van Moolenbroek  *  this is an ARP packet sent by a node in order to spontaneously cause other
86*5d5fbe79SDavid van Moolenbroek  *  nodes to update an entry in their ARP cache.
87*5d5fbe79SDavid van Moolenbroek  *  From RFC 3220 "IP Mobility Support for IPv4" section 4.6. */
88*5d5fbe79SDavid van Moolenbroek #define etharp_gratuitous(netif) etharp_request((netif), netif_ip4_addr(netif))
89*5d5fbe79SDavid van Moolenbroek void etharp_cleanup_netif(struct netif *netif);
90*5d5fbe79SDavid van Moolenbroek 
91*5d5fbe79SDavid van Moolenbroek #if ETHARP_SUPPORT_STATIC_ENTRIES
92*5d5fbe79SDavid van Moolenbroek err_t etharp_add_static_entry(const ip4_addr_t *ipaddr, struct eth_addr *ethaddr);
93*5d5fbe79SDavid van Moolenbroek err_t etharp_remove_static_entry(const ip4_addr_t *ipaddr);
94*5d5fbe79SDavid van Moolenbroek #endif /* ETHARP_SUPPORT_STATIC_ENTRIES */
95*5d5fbe79SDavid van Moolenbroek 
96*5d5fbe79SDavid van Moolenbroek #endif /* LWIP_IPV4 && LWIP_ARP */
97*5d5fbe79SDavid van Moolenbroek 
98*5d5fbe79SDavid van Moolenbroek void etharp_input(struct pbuf *p, struct netif *netif);
99*5d5fbe79SDavid van Moolenbroek 
100*5d5fbe79SDavid van Moolenbroek #ifdef __cplusplus
101*5d5fbe79SDavid van Moolenbroek }
102*5d5fbe79SDavid van Moolenbroek #endif
103*5d5fbe79SDavid van Moolenbroek 
104*5d5fbe79SDavid van Moolenbroek #endif /* LWIP_ARP || LWIP_ETHERNET */
105*5d5fbe79SDavid van Moolenbroek 
106*5d5fbe79SDavid van Moolenbroek #endif /* LWIP_HDR_NETIF_ETHARP_H */
107