mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
lwip: fix tcp stable test abort issue
1. Modify dhcp server timer to 1 seconds 2. Enable ETHARP_TRUST_IP_MAC modify according to review
This commit is contained in:
parent
29b32be97c
commit
ab37f89f55
@ -719,6 +719,8 @@ static u8_t parse_options(u8_t *optptr, s16_t len)
|
|||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
static s16_t parse_msg(struct dhcps_msg *m, u16_t len)
|
static s16_t parse_msg(struct dhcps_msg *m, u16_t len)
|
||||||
{
|
{
|
||||||
|
u32_t lease_timer = (dhcps_lease_time * 60)/DHCPS_COARSE_TIMER_SECS;
|
||||||
|
|
||||||
if (memcmp((char *)m->options, &magic_cookie, sizeof(magic_cookie)) == 0) {
|
if (memcmp((char *)m->options, &magic_cookie, sizeof(magic_cookie)) == 0) {
|
||||||
#if DHCPS_DEBUG
|
#if DHCPS_DEBUG
|
||||||
DHCPS_LOG("dhcps: len = %d\n", len);
|
DHCPS_LOG("dhcps: len = %d\n", len);
|
||||||
@ -745,7 +747,7 @@ static s16_t parse_msg(struct dhcps_msg *m, u16_t len)
|
|||||||
}
|
}
|
||||||
|
|
||||||
client_address.addr = pdhcps_pool->ip.addr;
|
client_address.addr = pdhcps_pool->ip.addr;
|
||||||
pdhcps_pool->lease_timer = dhcps_lease_time;
|
pdhcps_pool->lease_timer = lease_timer;
|
||||||
pnode = pback_node;
|
pnode = pback_node;
|
||||||
goto POOL_CHECK;
|
goto POOL_CHECK;
|
||||||
} else if (pdhcps_pool->ip.addr == client_address_plus.addr) {
|
} else if (pdhcps_pool->ip.addr == client_address_plus.addr) {
|
||||||
@ -783,7 +785,7 @@ static s16_t parse_msg(struct dhcps_msg *m, u16_t len)
|
|||||||
|
|
||||||
pdhcps_pool->ip.addr = client_address.addr;
|
pdhcps_pool->ip.addr = client_address.addr;
|
||||||
memcpy(pdhcps_pool->mac, m->chaddr, sizeof(pdhcps_pool->mac));
|
memcpy(pdhcps_pool->mac, m->chaddr, sizeof(pdhcps_pool->mac));
|
||||||
pdhcps_pool->lease_timer = dhcps_lease_time;
|
pdhcps_pool->lease_timer = lease_timer;
|
||||||
pnode = (list_node *)malloc(sizeof(list_node));
|
pnode = (list_node *)malloc(sizeof(list_node));
|
||||||
memset(pnode , 0x00 , sizeof(list_node));
|
memset(pnode , 0x00 , sizeof(list_node));
|
||||||
|
|
||||||
|
@ -166,6 +166,7 @@ enum dhcps_offer_option{
|
|||||||
OFFER_END
|
OFFER_END
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define DHCPS_COARSE_TIMER_SECS 1
|
||||||
#define DHCPS_MAX_LEASE 0x64
|
#define DHCPS_MAX_LEASE 0x64
|
||||||
#define DHCPS_LEASE_TIME_DEF (120)
|
#define DHCPS_LEASE_TIME_DEF (120)
|
||||||
|
|
||||||
|
@ -134,6 +134,10 @@ err_t etharp_raw(struct netif *netif, const struct eth_addr *ethsrc_addr,
|
|||||||
|
|
||||||
void etharp_arp_input(struct netif *netif, struct eth_addr *ethaddr, struct pbuf *p);
|
void etharp_arp_input(struct netif *netif, struct eth_addr *ethaddr, struct pbuf *p);
|
||||||
|
|
||||||
|
#if ETHARP_TRUST_IP_MAC
|
||||||
|
void etharp_ip_input(struct netif *netif, struct pbuf *p);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -585,6 +585,18 @@
|
|||||||
*/
|
*/
|
||||||
#define TCPIP_DEBUG LWIP_DBG_OFF
|
#define TCPIP_DEBUG LWIP_DBG_OFF
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ETHARP_TRUST_IP_MAC==1: Incoming IP packets cause the ARP table to be
|
||||||
|
* updated with the source MAC and IP addresses supplied in the packet.
|
||||||
|
* You may want to disable this if you do not trust LAN peers to have the
|
||||||
|
* correct addresses, or as a limited approach to attempt to handle
|
||||||
|
* spoofing. If disabled, lwIP will need to make a new ARP request if
|
||||||
|
* the peer is not already in the ARP table, adding a little latency.
|
||||||
|
* The peer *is* in the ARP table if it requested our address before.
|
||||||
|
* Also notice that this slows down input processing of every IP packet!
|
||||||
|
*/
|
||||||
|
#define ETHARP_TRUST_IP_MAC 1
|
||||||
|
|
||||||
|
|
||||||
/* Enable all Espressif-only options */
|
/* Enable all Espressif-only options */
|
||||||
|
|
||||||
|
@ -670,8 +670,7 @@ etharp_get_entry(u8_t i, ip4_addr_t **ipaddr, struct netif **netif, struct eth_a
|
|||||||
*
|
*
|
||||||
* @see pbuf_free()
|
* @see pbuf_free()
|
||||||
*/
|
*/
|
||||||
static void
|
void etharp_ip_input(struct netif *netif, struct pbuf *p)
|
||||||
etharp_ip_input(struct netif *netif, struct pbuf *p)
|
|
||||||
{
|
{
|
||||||
struct eth_hdr *ethhdr;
|
struct eth_hdr *ethhdr;
|
||||||
struct ip_hdr *iphdr;
|
struct ip_hdr *iphdr;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user