请教LPC1788+LWIP MAC地址设置问题

请教LPC1788+LWIP MAC地址设置问题,第1张

如果做得汇编程序,把目标地址做到数据池里。跳转的时候调到寄存器里用bx指令或blx指令。如果C语言程序不应该有这个错,因为编译器会自动解救这个问题。前提是将该段程序属性设置为位置无关。 查看原帖>>

如果做得汇编程序,把目标地址做到数据池里。跳转的时候调到寄存器里用bx指令或blx指令。如果C语言程序不应该有这个错,因为编译器会自动解救这个问题。前提是将该段程序属性设置为位置无关。 查看原帖>>

是 *** 作系统总内存不够,LWIP协议栈分配不到足够的内存导致的。

#define configTOTAL_HEAP_SIZE((size_t)(32*1024))//((size_t)15360)

解决!

LWIP是个轻量级的TCP/IP协议栈,之所以说轻量级,是因为作者将主体功能浓缩起来,做成这相对简单的协议栈,主要针对于ROM/RAM极缺极珍贵的环境下使用。

正是因为轻量、简单,所以平时很多理所当然的东西,大家都会觉得在这上面也能实现,实则不然,用过LWIP的人就会感觉到。

假如一种情况,你设置的IP/MAC与网络中其它设备冲突,这时既检测不到,更查不出是何原因,总是链接会无缘无故地断。

在这里,针对冲突这问题,提出一种解决方法,欢迎切磋纠正。

首先,需要了解一下,什么是Gratuitous ARP。有兴趣的可以百度一下,这里我就总结一下。当设备接入网络时,需要先发一个信息询问一下其它设备,“我发的这个IP,谁有?”。如果网络中存在这个IP,则会回复;

正是利用Gratuitous ARP这个东西,对其回复进行判断,如果接收到的响应或者回复,存在IP与设备自身相同,则标记为IP冲突。MAC冲突同理。

在LWIP中,对以下地方进行改进,则可实现MAC和IP冲突的检测。下面贴出主要部分代码。

etharp_arp_input(struct netif *netif, struct eth_addr *ethaddr, struct pbuf *p){

...

case PP_HTONS(ARP_REQUEST):

if(ip_addr_cmp(&sipaddr, &(netif->ip_addr))){

etharpError |= DUPLICATE_IP

}

if((hdr->shwaddr.addr[0] == netif->hwaddr[0])&&

(hdr->shwaddr.addr[1] == netif->hwaddr[1])&&

(hdr->shwaddr.addr[2] == netif->hwaddr[2])&&

(hdr->shwaddr.addr[3] == netif->hwaddr[3])&&

(hdr->shwaddr.addr[4] == netif->hwaddr[4])&&

(hdr->shwaddr.addr[5] == netif->hwaddr[5])){

etharpError |= DUPLICATE_MAC

}

...

case PP_HTONS(ARP_REPLY):

if(ip_addr_cmp(&sipaddr, &(netif->ip_addr))){

etharpError |= DUPLICATE_IP

}

if((hdr->shwaddr.addr[0] == netif->hwaddr[0])&&

(hdr->shwaddr.addr[1] == netif->hwaddr[1])&&

(hdr->shwaddr.addr[2] == netif->hwaddr[2])&&

(hdr->shwaddr.addr[3] == netif->hwaddr[3])&&

(hdr->shwaddr.addr[4] == netif->hwaddr[4])&&

(hdr->shwaddr.addr[5] == netif->hwaddr[5])){

etharpError |= DUPLICATE_MAC

}

...

在其它使用的地方只需判断etharpError 这个变量即可知道是否有冲突。因为Gratuitous ARP是机子一接入网络后初始化时发出的,所以可以不用担心是否在判断变量时还没检测到冲突。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/bake/11555367.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-17
下一篇2023-05-17

发表评论

登录后才能评论

评论列表(0条)

    保存