1: 定义数据模型 大小端 ARM 我定义为 #define BYTE_ORDER LITTLE_ENDIAN arch.h
增加定义 #define LWIP_PROVIDE_ERRNO
2: 定义mem_ptr_t类型 mem.h
3: 修改TCP_EVENT_RECV 定义中的 if(p).. 为if(p!=NULL).. tcp.h
4: 修改 socklen_t 类型为int sockets.h
5: 修改 #define SYS_ARCH_PROTECT(lev) OS_ENTER_CRITICAL()
#define SYS_ARCH_UNPROTECT(lev) OS_EXIT_CRITICAL() sys.h
并对其中的函数重新排版 修改移植部分 函数参数的相关变化
sys_thread_new 等
6: ne2k.c
修改ethernetif_input函数 按照新的接口直接把数据传递给 ethernet_input函数
修改ethernetif_output函数 此函数删除掉
修改ethernetif_init函数 netif->output = etharp_output;//ethernetif_output; 现在用etharp_output函数替代
对其他的函数做了些小的修改
ne2k_data_check 函数 增加了 接收错误的返回值处理
ne2k_isr函数 增加了处理网络错误的处理 即可能是重新设置接收缓存等操作
修改ethernetif_init 函数 去掉 sys_timeout(ARP_TMR_INTERVAL, arp_timer, NULL);
因为LWIP 1.3版本已经在TCPIP.C 的tcpip_thread初始化了
而且arp_timer(void *arg) 函数也移到了TCPIP.C里面
修改了etharp_init部分 去掉了这个函数在修改ethernetif_init的存在 因为tcpip_thread已经调用
7: 在sys_arch.c中添加了两个新的函数 sys_arch_mbox_tryfetch 跟sys_mbox_trypost
按照新的sys_thread_new的函数参数 修改了部分代码 但是继续没有使用name stacksize两个参数 以后修改
8: a>内存池地址对齐问题 修改opt.h lwipopt.h 中的MEM_ALIGNMENT 为4 其他的配置根据情况做小的修改
这里为了组播功能 激活IGMP
b>.ip头部对齐当接收到http访问的IP包时,再次出现Dabort exception!!!错误。跟踪发现在ip_input里
if (ip_addr_cmp(&(iphdr->dest), &(netif->ip_addr)) ||
这一句有问题,iphdr->dest存放在2字节对齐的内存里,而ip_addr_cmp访问时一次读入4个字节,需4字节对齐。
由iphdr = p->payload跟踪payload存放的地址,当驱动收到以太包上传时,payload是指向4字节对齐的地址。
但进入ethernet_input,再传给ip_input后,payload的地址发生了变化,增加了14个字节,导致字节对齐出现问题。
仔细一看,发现问题在这一句:if(pbuf_header(p, -(s16_t)sizeof(struct eth_hdr))) {
ARM当跳过已处理的物理地址时,sizeof(struct eth_hdr)恰好为14字节…问题的解决也很简单,
LWIP已经准备了硬件地址补齐的预定义,使用#define ETH_PAD_SIZE 2 补齐2字节即可。
c> 5.数据分包大小 移植好的HTTP server工作很正常,但修改一下输出的内容,发现又不能工作 重复修改输出的内容,
发现一超过128字节时,程序工作不正常。用Wireshark抓包,发现输出的内容被切割成多个小包。一把抓住一个,
仔细一看,发现一个数字很熟悉,就是MSS=128
d> ARM RAM内存对齐问题 参考访问http://www.cpper.com/zweily/68.html
E> 系统要分配足够的事件控制块 OS_MAX_EVENT
8: 测试组播功能
这个是我移植1.3.0的版本时候写了一些 可惜不完整 呵呵 你参考参考下表吧. |